SPA项目开发之登录注册

目录

一、前置工作

准备步骤:

1、确保后台项目T216_SSH能够运行起来,标志: http://localhost:8080/T216_SSH/vue/treeNodeAction.action 能够返回数据

2、要将api的文件夹导入src的目录

3、下载js依赖

        axios:前端向后台发送请求

        qs:解决发送post请求代码冗余的问题

        ElementUI:快速布局

        vue-axios:将axios依赖整合进vue中

二、用户登录界面排版

三、Vue之数据交互登录功能

this.$router.push(.....);

作用:试用获取后台数据,做局部刷新

语法:

this.axios.post(url,this.param)

.then(function(resp){ })

.catch(function(error){ })

四、this指针污染

五、CORS跨域

 跨域产生的因素:协议、ip、端口、项目有任意一处发生改变,都会产生跨域的现象

六、工具类的作用&get和post的区别

引入main.js配置

解决

axios、qs的作用

api/http.js:

get/post


一、前置工作

准备步骤:

1、确保后台项目T216_SSH能够运行起来,标志:  http://localhost:8080/T216_SSH/vue/treeNodeAction.action 能够返回数据

2、要将api的文件夹导入src的目录

3、下载js依赖

        axios:前端向后台发送请求

        qs:解决发送post请求代码冗余的问题

        ElementUI:快速布局

        vue-axios:将axios依赖整合进vue中

eclipse导入项目:

选择maven工程:

             

 选择项目所在路径:

 

导入成功后再运行:

要注意Tomact的配置问题!) 

之后测试能不能访问到数据,如下: 

 

 返回了数据:

紧接着去黑窗口下载四个js依赖:

你们可以在项目所在的目录下去执行: 

 

由于本人下载了WebStorm

因此我直接在那里面输入:

 下载成功后注意package.json有没有生成 element-ui:

 成功后继续下载:

 

 将以下四个依赖下载完之后,

 npm install element-ui -S 

npm install axios -S

npm install qs -S  

npm install vue-axios -S

对应的 package.json 里面也生成了四个依赖:

前置工作已都准备完毕!

二、用户登录界面排版

 复制到App.vue中:

<template>
  <div id="app">
    <el-row>
      <el-button>默认按钮</el-button>
      <el-button type="primary">主要按钮</el-button>
      <el-button type="success">成功按钮</el-button>
      <el-button type="info">信息按钮</el-button>
      <el-button type="warning">警告按钮</el-button>
      <el-button type="danger">危险按钮</el-button>
    </el-row>
    <!-- 锚点-->
    <router-view/>
  </div>
</template>

<script>
export default {
  name: 'App'
}
</script>

<style>
#app {
  font-family: 'Avenir', Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

npm run dev 运行:

 目前页面效果这样:

接下来写我们的登录界面:

 复制到新建的views文件夹内的Login.vue中:

然后其中进行调整代码即样式:

Login.vue:

<template>
  <div class="login-wrap">
    <el-row>
      <el-col :span="24">
        <div style="text-align: center" class="grid-content bg-purple-dark"><h3>用户登录</h3>
      </div></el-col>
    </el-row>

    <el-form :model="ruleForm" status-icon label-width="100px" class="demo-ruleForm login-container">
      <el-form-item label="用户名" prop="uname">
        <el-input type="text" v-model="ruleForm.uname" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item label="密码" prop="pwd">
        <el-input type="password" v-model="ruleForm.pwd" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item>
        <el-row>
          <el-col :span="24">
            <div style="text-align: center" class="grid-content bg-purple-dark">
              <el-button style="width: 100%" type="primary" @click="submitForm">提交</el-button>
            </div>
          </el-col>
        </el-row>
      </el-form-item>
      <el-form-item>
        <el-row>
          <el-col :span="12">
            <div style="text-align: center" class="grid-content bg-purple-dark">
              <el-link type="success">用户注册</el-link>
            </div>
          </el-col>
          <el-col :span="12">
          <div style="text-align: center" class="grid-content bg-purple-dark">
            <el-link type="warning">忘记密码</el-link>
          </div>
          </el-col>
        </el-row>
      </el-form-item>

    </el-form>
  </div>
</template>

<script>
export default {
  name: 'Login',
  data () {
    return {
      ruleForm: {}
    }
  },
  methods:{
    submitForm(){

    },
    resetForm(){

    }
  }
}
</script>

<style scoped>
.login-wrap {
  box-sizing: border-box;
  width: 100%;
  height: 100%;
  padding-top: 10%;
  background-image: url();
  /* background-color: #112346; */
  background-repeat: no-repeat;
  background-position: center right;
  background-size: 100%;
}

.login-container {
  border-radius: 10px;
  margin: 0px auto;
  width: 350px;
  padding: 30px 35px 15px 35px;
  background: #fff;
  border: 1px solid #eaeaea;
  text-align: left;
  box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
}

.title {
  margin: 0px auto 40px auto;
  text-align: center;
  color: #505458;
}
</style>

index.js:

import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from "../components/HelloWorld";
import Login from "../views/Login";

Vue.use(Router)

export default new Router({
  routes: [
    {
      path: '/',
      name: 'Login',
      component: Login
    },
    {
      path: '/Login',
      name: 'Login',
      component: Login
    },
  ]
})

App.vue:

<template>
  <div id="app">

    <!-- 锚点-->
    <router-view/>
  </div>
</template>

<script>
export default {
  name: 'App'
}
</script>

<style>
html,
body {
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  padding: 0px;
  margin: 0px;
}
#app {
  font-family: "Avenir", Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color: #2c3e50;
  widows: 100%;
  height: 100%;
}
</style>

 main.js:

// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'
import ElementUI from 'element-ui' // 新添加 1
import 'element-ui/lib/theme-chalk/index.css' // 新添加 2 ,避免后期打包样式
import App from './App'
import router from './router'

Vue.use(ElementUI)//新添加 3
Vue.config.productionTip = false

/* eslint-disable no-new */
new Vue({
  el: '#app',
  router,
  components: { App },
  template: '<App/>'
})

页面运行效果:

 用户登录界面排版完成~

三、Vue之数据交互登录功能

this.$router.push(.....);

axios相当于jQuery中的ajax

作用:试用获取后台数据,做局部刷新

语法:

this.axios.post(url,this.param)

.then(function(resp){ })

.catch(function(error){ })

 首先再添加一个用户注册,实现登录时假若没有注册就可以跳转注册页面:

Reg.vue:

<template>
  <div class="login-wrap">
    <el-row>
      <el-col :span="24">
        <div style="text-align: center" class="grid-content bg-purple-dark"><h3>用户注册</h3>
      </div></el-col>
    </el-row>

    <el-form :model="ruleForm" status-icon label-width="100px" class="demo-ruleForm login-container">
      <el-form-item label="用户名" prop="uname">
        <el-input type="text" v-model="ruleForm.uname" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item label="密码" prop="pwd">
        <el-input type="password" v-model="ruleForm.pwd" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item>
        <el-row>
          <el-col :span="24">
            <div style="text-align: center" class="grid-content bg-purple-dark">
              <el-button style="width: 100%" type="primary" @click="submitForm">提交</el-button>
            </div>
          </el-col>
        </el-row>
      </el-form-item>
      <el-form-item>
        <el-row>
          <el-col :span="12">
            <div style="text-align: center" class="grid-content bg-purple-dark">
              <el-link type="success"  @click="toLogin">用户登录</el-link>
            </div>
          </el-col>
          <el-col :span="12">
          <div style="text-align: center" class="grid-content bg-purple-dark">
            <el-link type="warning">忘记密码</el-link>
          </div>
          </el-col>
        </el-row>
      </el-form-item>

    </el-form>
  </div>
</template>

<script>
export default {
  name: 'Reg',
  data () {
    return {
      ruleForm: {}
    }
  },
  methods:{
    submitForm(){

    },
    resetForm(){

    },
    toLogin(){
      this.$router.push({path:'/Login'})
    }
  }
}
</script>

<style scoped>
.login-wrap {
  box-sizing: border-box;
  width: 100%;
  height: 100%;
  padding-top: 10%;
  background-image: url();
  /* background-color: #112346; */
  background-repeat: no-repeat;
  background-position: center right;
  background-size: 100%;
}

.login-container {
  border-radius: 10px;
  margin: 0px auto;
  width: 350px;
  padding: 30px 35px 15px 35px;
  background: #fff;
  border: 1px solid #eaeaea;
  text-align: left;
  box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
}

.title {
  margin: 0px auto 40px auto;
  text-align: center;
  color: #505458;
}
</style>

index.js:

import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from "../components/HelloWorld";
import Login from "../views/Login";
import Reg from "../views/Reg";

Vue.use(Router)

export default new Router({
  routes: [
    {
      path: '/',
      name: 'Login',
      component: Login
    },
    {
      path: '/Login',
      name: 'Login',
      component: Login
    },
    {
      path: '/Reg',
      name: 'Reg',
      component: Reg
    }
  ]
})

效果: 

进行数据交互登录功能的实现:

<template>
  <div class="login-wrap">
    <el-row>
      <el-col :span="24">
        <div style="text-align: center" class="grid-content bg-purple-dark"><h3>用户登录</h3>
      </div></el-col>
    </el-row>

    <el-form :model="ruleForm" status-icon label-width="100px" class="demo-ruleForm login-container">
      <el-form-item label="用户名" prop="uname">
        <el-input type="text" v-model="ruleForm.uname" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item label="密码" prop="pwd">
        <el-input type="password" v-model="ruleForm.pwd" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item>
        <el-row>
          <el-col :span="24">
            <div style="text-align: center" class="grid-content bg-purple-dark">
              <el-button style="width: 100%" type="primary" @click="submitForm">提交</el-button>
            </div>
          </el-col>
        </el-row>
      </el-form-item>
      <el-form-item>
        <el-row>
          <el-col :span="12">
            <div style="text-align: center" class="grid-content bg-purple-dark">
              <el-link type="success"  @click="toReg">用户注册</el-link>
            </div>
          </el-col>
          <el-col :span="12">
          <div style="text-align: center" class="grid-content bg-purple-dark">
            <el-link type="warning">忘记密码</el-link>
          </div>
          </el-col>
        </el-row>
      </el-form-item>

    </el-form>
  </div>
</template>

<script>
export default {
  name: 'Login',
  data () {
    return {
      ruleForm: {}
    }
  },
  methods:{
    submitForm(){
      //this.axios找到的是 /api/http.js文件
      //xios.urls——>this.axios/urls找到了 /api/action.js
      //action.js是一个JSON对象,那么就可以取到请求的值
      let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
      // alert(url);
      // {uname:'zs',pwd:'123'}
      this.axios.post(url,this.ruleForm)
        .then(function (resp){//代表成功
        console.log(resp);
      }).catch(function (){//代表失败

      });
    },
    resetForm(){

    },
    toReg(){
      this.$router.push({path:'/Reg'})
    }
  }
}
</script>

<style scoped>
.login-wrap {
  box-sizing: border-box;
  width: 100%;
  height: 100%;
  padding-top: 10%;
  background-image: url();
  /* background-color: #112346; */
  background-repeat: no-repeat;
  background-position: center right;
  background-size: 100%;
}

.login-container {
  border-radius: 10px;
  margin: 0px auto;
  width: 350px;
  padding: 30px 35px 15px 35px;
  background: #fff;
  border: 1px solid #eaeaea;
  text-align: left;
  box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
}

.title {
  margin: 0px auto 40px auto;
  text-align: center;
  color: #505458;
}
</style>

直接点击提交:

 输错密码:

 输入正确:

 到这里呢,那么我们的Vue的数据交互登录功能就已实现啦!

四、this指针污染

当我们登录时 密码错误/密码正确/账户密码为空 时,要出现相应的消息提示框,所以我们可去element官网上进行查找我们需要的提示框源代码:

 我们就以成功和错误的消息提示来做案例:

 进行代码调整:

Login.vue:

<script>
export default {
  name: 'Login',
  data () {
    return {
      ruleForm: {}
    }
  },
  methods:{
    submitForm(){
      //this.axios找到的是 /api/http.js文件
      //xios.urls——>this.axios/urls找到了 /api/action.js
      //action.js是一个JSON对象,那么就可以取到请求的值
      let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
      // {uname:'zs',pwd:'123'}

      //this指的是vue实例
      this.axios.post(url,this.ruleForm)
        .then(resp => {//代表成功 箭头函数 jdk8的语法
        console.log(resp);
        if(resp.data.code == 1){
          //this指的是http.js
          this.$message({
            message: resp.data.msg,
            type: 'success'
          });
        }else if(resp.data.code == 0) {
          //this指的是http.js
          this.$message.error(resp.data.msg);
        }
      }).catch(function (){//代表失败

      });
    },
    resetForm(){

    },
    toReg(){
      this.$router.push({path:'/Reg'})
    }
  }
}
</script>

 未填任何数据,直接提交:

 填写错误用户或者密码:

 填写正确用户或者密码:

五、CORS跨域

在T216_SSH项目中的web.xml有个解决cors跨域问题的过滤器:

 再去运行项目,直接点提交:

跨域的现象:

请求地址由协议+ip+端口+项目+....等构成

 跨域产生的因素:协议、ip、端口、项目有任意一处发生改变,都会产生跨域的现象

解决方案: 

package com.javaxl.util;

import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletResponse;

/**
 * 配置tomcat允许跨域访问
 * 
 * @author Administrator
 *
 */
public class CorsFilter implements Filter {

	@Override
	public void init(FilterConfig filterConfig) throws ServletException {
	}

	@Override
	public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)
			throws IOException, ServletException {
		HttpServletResponse httpResponse = (HttpServletResponse) servletResponse;

		// Access-Control-Allow-Origin就是我们需要设置的域名
		// Access-Control-Allow-Headers跨域允许包含的头。
		// Access-Control-Allow-Methods是允许的请求方式
		httpResponse.addHeader("Access-Control-Allow-Origin", "*");// *,任何域名
		httpResponse.setHeader("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
		httpResponse.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, DELETE");
		filterChain.doFilter(servletRequest, servletResponse);
	}

	@Override
	public void destroy() {

	}
}

六、工具类的作用&get和post的区别

引入main.js配置

// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'
import 'element-ui/lib/theme-chalk/index.css' // 新添加 2
import App from './App'
import router from './router'
import ElementUI from 'element-ui' // 新添加 1
// import axios from '@/api/http' 
import axios from 'axios'
import VueAxios from 'vue-axios'

Vue.use(ElementUI)
Vue.use(VueAxios,axios)
Vue.config.productionTip = false

/* eslint-disable no-new */
new Vue({
  el: '#app',
  router,
  components: { App },
  template: '<App/>'
})
let url = 'http://localhost:8080/T216_SSH/vue/userAction_login.action';

				this.axios.post(url, this.ruleForm).then(function(response) {
					console.log(response);
				}).catch(function(error) {
					console.log(error);
				});

 

解决

import qs from 'qs'
let url = 'http://localhost:8080/T216_SSH/vue/userAction_login.action';

				this.axios.post(url, qs.stringify(this.ruleForm)).then(function(response) {
					console.log(response);
				}).catch(function(error) {
					console.log(error);
				});

axios、qs的作用

api/http.js:

        1、将原生的json对象转换成字符串,通过拦截器转

        2、将本项目中的所有接口地址,进行统一管理

get/post

        get请求:

let url = this.axios.urls.SYSTEM_USER_DOLOGIN;

				this.axios.get(url, { //注意数据是保存到json对象的params属性
					params: this.ruleForm
				}).then(function(response) {
					console.log(response);
				}).catch(function(error) {
					console.log(error);
				});

        post请求:

let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
				
				this.axios.post(url, this.ruleForm).then(function(response) {
					console.log(response);
				}).catch(function(error) {
					console.log(error);
				});

今日分享就结束啦!如果觉得对您有帮助的话可以点点赞好嘛~

酒醉猫(^・ェ・^)
关注 关注
  • 6
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
eclipse + MySQL+struts 实现登录注册
09-13
通过注册写入数据库,通过数据库进行比对,用户注册则返回已注册重新输入。本地数据库功能,当注册完成,系统写入数据库表中,再次注册相同用户时返回已注册
用Vue实现一个登陆界面
aobu511721的专栏
03-24 4530
总是从园子里索取,所以也想写点东西,欢迎大家批评指教。 最近由于一些原因,开始学习vue的项目开发,对于我这样一个刚刚入行的菜鸟级c#程序员,可真踩了不少坑, 接下来,废话少说。 一、搭建环境 本人win10开发环境(资深大佬勿喷,我没有mac,也没有安装linux环境) 1.首先安装node环境,本项目中主要是用来做包管理。传送门(https://nodejs.org/zh-...
Eclipse用SSH框架实现登陆注册功能
aijima0904的博客
04-09 9196
第一次写博文,写的不好的地方还请多多指教。关于SSH搭建大家可以看这篇博文,讲的很详细,是搭建SSH框架具有注册功能的例子http://blog.csdn.net/lpftobetheone/article/details/17783791我也是第一次搭SSH框架参考这篇博文成功搭起来后也可以运行,但是其中的具体逻辑我还是不太懂,所以自己决定在此基础上增加登录的功能来进行摸索学习。我先说一下每个类的
Eclipse+servlet+Tomcat+MySQL实现登入注册页面
QMZQDF的博客
07-01 6599
servlet前后端交互,一个简单的登入注册页面
Laravel-Vue SPA入门项目模板。-PHP开发
05-27
具有动态导入和自定义布局的Laravel 7 Vue + VueRouter + Vuex + VueI18n + ESlint页面登录,注册,发送电子邮件验证Laravel-Vue SPA Laravel-Vue SPA入门项目模板。 功能Laravel 7 Vue + VueRouter + Vuex + VueI...
Hotel-Spa:高品位DAW项目
05-29
项目目的该项目前端和后端都在 Laravel 中开发,后者在本地服务器上作为 xampp 运行。 该项目源于在线预订房间时的舒适理念,将这些预订扩展到酒店水疗中心提供的所有服务,包括客房服务和美容护理,包括在您的...
tt.rar后台代码资源
08-14
SPA项目开发登录注册+动态树+数据表格+分页的后台部分
single-spa-vue:微前端框架single-spa 整合vue项目
05-30
运行demo ...微前端项目是由多个子项目组成的,所以需要在微前端项目中声明这个项目是由哪些子项目组成的,这个步骤称为子项目注册。子项目注册做的事情是:给这个项目命名,指定这个项目在什么情况下装
SpringBoot项目数码论坛系统设计与实现.zip
04-15
1. 用户注册与登录:用户可以创建个人账户并登录论坛,进行各种操作。 2. 发帖与管理:用户可以在论坛中发布新的主题帖,并对已发的帖子进行编辑、删除等管理操作。 3. 分类标签:帖子可以根据不同的数码产品类别...
Oracle、eclipse、html登录注册框架(以实现主要功能)
09-12
功能实现(适用于较初学者) Oracle数据库与eclipse与前台html建立框架 ******************* 用户登录、注册 ******************* 登录: 实现用户登陆验证输入信息与数据库信息进行匹配 ******************* 注册: 实现用户注册输入信息后台数据库存储 (验证注册账号密码验证码是否为空功能) (账号密码正则表达式验证规范)
Eclipse+sql做的用户登录注册系统
02-27
用户名:admin 密码:admin Eclipse+sql做的用户登录注册系统,简单的入门项目啊,拿来分享一下啊
ssm框架实现简单的登录注册功能
06-26
项目基于ssm框架,在我的博客中,从搭配环境到实现功能一步步都有截图,你可以在这里下载,当然也可以跟着截图复制粘贴,刚刚接触java和ssm,所以代码可能比较low,仅供新手参考参考,练练手。说白了就是,拿着玩去吧。
使用eclipse编写的登录Demo
01-11
自己制作的登录小例子 很多地方不是很完善 功能仅限登录 注册 修改密码 注销 邮箱没有用正则表达式验证 例子不涉及ajax等技术 没有用到框架 使用JDBC对数据库进行的操作 这个例子采用eclipse编写 Oracle11gXE数据库 运行只需将src/com/lzy/dbutil/DbUtil中的具体代码改成自己的数据库 并将sql文件导入即可
简单的java Web实现登录注册功能
12-24
Today we all are aware of the need of creating dynamic web pages i.e the ones which have the capability to change the site contents according to the time or are able to generate the contents according to the request received by the client. If you like coding in Java, then you will be happy to know that using Java there also exists a way to generate dynamic web pages and that way is Java Servlet. But before we move forward with our topic let’s first understand the need for server-side extensions. Servlets are the Java programs that runs on the Java-enabled web server or application server. They are used to handle the request obtained from the web server, process the request, produce the response, then send response back to the web server.
java eclipse登录注册功能_eclipse中SSM(maven)项目搭建全过程+实现用户登录功能
weixin_39632982的博客
02-16 2658
项目创建之前确保eclipse中已经配置好了jdk,tomcat,maven如果没有配置下面有配置教程的链接一,创建maven项目1,新建一个maven项目2,点击Next后进入下个页面直接点击Next,进入到下面这个页面3,我们选择最后单词为webapp的这个选项选中后点击Next,进入到下面的这个页面此处的Group Id代表的是项目的包路径,Artifact Id代表的是项目的名称Versi...
【Android】eclipse 实现登录、注册、修改密码、数据库操作
weixin_44480960的博客
07-19 8769
项目参考:https://blog.csdn.net/midnight_time/article/details/91203973 目录 登录、注册、修改密码功能的实现 一、UI的设计 二、实现功能部分,Java文件 登录、注册、修改密码功能的实现 一、UI的设计 1.主界面的布局文件 main.xml文件代码如下所示: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/...
Vue实现一个简单的登录页面【自定义】
qq_46556714的博客
11-05 5061
创建一个自定义插件 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <t
element-ui的bug记录
最新发布
nick_zhang的博客
04-29 395
7.el-dialog组件在关闭时,会触发子组件的created/mounted生命周期。原因是当visible改变为false,即关闭dialog的时候,如果用户设置了destroyOnClose=true,则执行key++;key是绑定在较外层的div上的,key值的变化会导致这个div重新渲染。6.select 的 popper-append-to-body ,默认值为true;dialog的append-to-body,默认值为false;3.element表格前端分页。
推荐一些vue实战项目
09-26
2. Vue论坛:可以创建一个基于Vue.js的论坛应用,这个项目可以涉及用户注册、登录、发帖、评论等功能。通过这个项目可以学习到如何使用Vue.js构建一个实际的应用,以及如何处理用户数据、路由导航和表单验证等问题。...

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
写文章

热门文章

  • 若依项目环境搭建及使用 8703
  • jQuery01(入门&选择器) 6636
  • OA项目之我的审批(查询&会议签字) 3929
  • SpringBoot电商项目之购物车下单(沙箱支付) 3225
  • SpringBoot完成查询和增加功能(简易版) 2953

最新评论

  • 医疗项目业务介绍

    云村小威: 业务详细,值得收藏表情包

  • SpringBoot电商项目前后端界面搭建

    已月十七: 博主你的js/css/images发出来了吗?没有看到有啊

  • 若依项目环境搭建及使用

    酒醉猫(^・ェ・^): 它本来就是ssm表情包

  • 若依项目环境搭建及使用

    yangshanyyqx: 请问这个框架可以做SSM项目吗?

  • 若依项目环境搭建及使用

    J T R: 大佬你的ssm脚本能发出来吗?

您愿意向朋友推荐“博客详情页”吗?

  • 强烈不推荐
  • 不推荐
  • 一般般
  • 推荐
  • 强烈推荐
提交

最新文章

  • 秒杀项目之消息推送
  • 秒杀项目之商品秒杀接口压测及优化
  • 秒杀项目之商品展示及商品秒杀
2023年13篇
2022年128篇

目录

目录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43元 前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

酒醉猫(^・ェ・^)

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或 充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值

深圳SEO优化公司肇庆seo哪家好保山企业网站建设推荐济南网站搜索优化公司焦作百度竞价包年推广哪家好德州外贸网站设计公司杭州百搜标王成都网站优化报价内江如何制作网站报价芜湖网站推广价格清徐高端网站设计价格渭南企业网站制作推荐南平网页设计公司那曲高端网站设计咸宁百度seo报价南通阿里店铺运营公司南联网络营销价格坑梓优化多少钱安顺建设网站推荐鹰潭SEO按效果付费推荐伊春模板推广价格三明阿里店铺运营多少钱菏泽关键词按天收费双龙网站设计哪家好怀化网站制作设计多少钱濮阳如何制作网站多少钱黔西南网站设计多少钱海口网站推广系统多少钱海口设计网站哪家好宁德网站推广工具价格永新百姓网标王哪家好歼20紧急升空逼退外机英媒称团队夜以继日筹划王妃复出草木蔓发 春山在望成都发生巨响 当地回应60岁老人炒菠菜未焯水致肾病恶化男子涉嫌走私被判11年却一天牢没坐劳斯莱斯右转逼停直行车网传落水者说“没让你救”系谣言广东通报13岁男孩性侵女童不予立案贵州小伙回应在美国卖三蹦子火了淀粉肠小王子日销售额涨超10倍有个姐真把千机伞做出来了近3万元金手镯仅含足金十克呼北高速交通事故已致14人死亡杨洋拄拐现身医院国产伟哥去年销售近13亿男子给前妻转账 现任妻子起诉要回新基金只募集到26元还是员工自购男孩疑遭霸凌 家长讨说法被踢出群充个话费竟沦为间接洗钱工具新的一天从800个哈欠开始单亲妈妈陷入热恋 14岁儿子报警#春分立蛋大挑战#中国投资客涌入日本东京买房两大学生合买彩票中奖一人不认账新加坡主帅:唯一目标击败中国队月嫂回应掌掴婴儿是在赶虫子19岁小伙救下5人后溺亡 多方发声清明节放假3天调休1天张家界的山上“长”满了韩国人?开封王婆为何火了主播靠辱骂母亲走红被批捕封号代拍被何赛飞拿着魔杖追着打阿根廷将发行1万与2万面值的纸币库克现身上海为江西彩礼“减负”的“试婚人”因自嘲式简历走红的教授更新简介殡仪馆花卉高于市场价3倍还重复用网友称在豆瓣酱里吃出老鼠头315晚会后胖东来又人满为患了网友建议重庆地铁不准乘客携带菜筐特朗普谈“凯特王妃P图照”罗斯否认插足凯特王妃婚姻青海通报栏杆断裂小学生跌落住进ICU恒大被罚41.75亿到底怎么缴湖南一县政协主席疑涉刑案被控制茶百道就改标签日期致歉王树国3次鞠躬告别西交大师生张立群任西安交通大学校长杨倩无缘巴黎奥运

深圳SEO优化公司 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化