目录
一、项目展示
data:image/s3,"s3://crabby-images/c360c/c360cb37a1680eb95b785d307b2ebe32f7b2aa33" alt=""
data:image/s3,"s3://crabby-images/52b6d/52b6df59de308821701dad61b64d175c12896095" alt=""
data:image/s3,"s3://crabby-images/5f518/5f5181b0f7bcd3d8f24be61f3405f8ea7fd8c624" alt=""
data:image/s3,"s3://crabby-images/39475/39475626e171400edeb746fb6c979c9d8cf19839" alt=""
data:image/s3,"s3://crabby-images/63283/63283c2cd9b5e57722030cc9bc48e0f95ccdb565" alt=""
data:image/s3,"s3://crabby-images/7d5ae/7d5ae701c54969b6c34d18997be1104542390afb" alt=""
data:image/s3,"s3://crabby-images/aa6a4/aa6a40d6dc58b619253f1a9959b10dcaacf83f4b" alt=""
data:image/s3,"s3://crabby-images/3ccb8/3ccb881f4d13e58e21af72877f7c9e9040119937" alt=""
data:image/s3,"s3://crabby-images/14c87/14c87abc504ef69bdc7de27e7fa10e1368acf17a" alt=""
二、项目创建
创建文件夹使用VsCode打开后,新建终端输入以下命令
打开UI创建项目
npm install -g @vue/cli # 安装vue
vue -ui # 在浏览器创建项目
UI创建步骤
data:image/s3,"s3://crabby-images/55325/553251a86efa9ec5d960ab9d4b04984461f22440" alt=""
data:image/s3,"s3://crabby-images/60cd8/60cd8cf6586a928c2832c9b19bb1a3ba00483df5" alt=""
data:image/s3,"s3://crabby-images/ed76f/ed76f98b81a6b77570d46d0590dfbe83ba04cc2a" alt=""
data:image/s3,"s3://crabby-images/31019/31019c6a97fccba9149f0507ed0181d6c82938c9" alt=""
data:image/s3,"s3://crabby-images/605ae/605ae7166a7059cd16a031193e48202caa2c5910" alt=""
配置端口与代理
const { defineConfig } = require('@vue/cli-service')
module.exports = defineConfig({
transpileDependencies: true,
devServer: {
port: 9898,
proxy: {
'/api': {
target: "http://localhost:9897",
changeOrigin: true
}
}
}
})
data:image/s3,"s3://crabby-images/d25dd/d25dd7a3cf415a3a6a4a685b3b53216296a9646c" alt=""
data:image/s3,"s3://crabby-images/3b7dc/3b7dcb33cad598fa722ec1fc44afc3ae1b9323dc" alt=""
data:image/s3,"s3://crabby-images/04de1/04de1164b28a7c6d965f58ac2e6baf9028a3b8fd" alt=""
三、Vue语法
文本插值
<template>
<div id="app">
{{problems[0].id + problems[1].id}} {{problems[0].title}} {{problems[0].level}}
{{problems[0].level === "easy" ? "easy" : "other"}}
</div>
</template>
<script>
const options = {
data: function () {
return {
problems: [
{id: 1, title: "两数之和1", level: "easy"},
{id: 2, title: "两数之和2", level: "easy"},
{id: 3, title: "两数之和3", level: "easy"}
]
};
}
};
export default options;
</script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
}
nav {
padding: 30px;
}
nav a {
font-weight: bold;
color: #2c3e50;
}
nav a.router-link-exact-active {
color: #42b983;
}
</style>
data:image/s3,"s3://crabby-images/1ef16/1ef1691f5443c36346cce851f8633d7fa30152c8" alt=""
属性绑定
<template>
<div id="app">
<input type="text" v-bind:value="name">
<input type="text" :value="name">
</div>
</template>
<script>
const options = {
data: function () {
return {
name: "王五"
};
}
};
export default options;
</script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
}
nav {
padding: 30px;
}
nav a {
font-weight: bold;
color: #2c3e50;
}
nav a.router-link-exact-active {
color: #42b983;
}
</style>
data:image/s3,"s3://crabby-images/8af4e/8af4e2f92f4410b49727fbe09fe2164a06363b16" alt=""
data:image/s3,"s3://crabby-images/c067d/c067d71683755de19fc6446f79bb471f04c98d1d" alt=""
事件绑定
<template>
<div id="app">
<input type="button" v-bind:value="msg" v-on:click="login">
<input type="button" v-bind:value="msg" @click="login">
</div>
</template>
<script>
const options = {
data: function () {
return {
msg: "点我"
};
},
methods: {
login: function () {
alert(options.data().msg)
}
}
};
export default options;
</script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
}
nav {
padding: 30px;
}
nav a {
font-weight: bold;
color: #2c3e50;
}
nav a.router-link-exact-active {
color: #42b983;
}
</style>
data:image/s3,"s3://crabby-images/c7caf/c7cafb45e4572136463f7e4fd6cee4c7785c9d66" alt=""
案例加法器实现
<template>
<div id="app">
<input type="button" v-bind:value="addMessage" v-on:click="add">
{{cnt}}
<input type="button" v-bind:value="subMessage" @:click="sub">
</div>
</template>
<script>
const options = {
data: function () {
return {
addMessage: "点我+1",
subMessage: "点我-1",
cnt: 1
};
},
methods: {
sub: function () {
this.cnt = this.cnt - 1;
alert(this.cnt);
},
add: function () {
this.cnt = this.cnt + 1;
alert(this.cnt);
}
}
};
export default options;
</script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
}
nav {
padding: 30px;
}
nav a {
font-weight: bold;
color: #2c3e50;
}
nav a.router-link-exact-active {
color: #42b983;
}
</style>
data:image/s3,"s3://crabby-images/70661/70661a02056e2979b89f7c0ef2147d801760a5b1" alt=""
双向绑定
<template>
<div id="app">
<input type="text" v-model="name">
{{name}}
</div>
</template>
<script>
const options = {
data: function () {
return {
name: "王五"
};
},
methods: {
}
};
export default options;
</script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
}
nav {
padding: 30px;
}
nav a {
font-weight: bold;
color: #2c3e50;
}
nav a.router-link-exact-active {
color: #42b983;
}
</style>
data:image/s3,"s3://crabby-images/94af1/94af16f5c94487aae3e89f3c769ff1ae4a6c55c2" alt=""
axios
安装
npm install axios -S
基础请求
data:image/s3,"s3://crabby-images/27fdf/27fdf85f1365f39fdb1817ae9689d0fbd8c6597f" alt=""
token
data:image/s3,"s3://crabby-images/719c3/719c334b964c5119826bc75c4f42d4f0fe469b7a" alt=""
携带参数
data:image/s3,"s3://crabby-images/dae26/dae2696a93ce1506dd35372f24194ea3f8002976" alt=""
配置中携带参数
data:image/s3,"s3://crabby-images/abaf1/abaf1d436edc0ac6ab757e67489211d542a5c474" alt=""
请求体携带参数(默认json)
data:image/s3,"s3://crabby-images/c1f48/c1f485ab3294cac4b5f34936997cfd93a6e8d954" alt=""
请求体携带参数(不使用json)
data:image/s3,"s3://crabby-images/6f742/6f742627b19fc18d11d850de4bf3a0cfca020ff5" alt=""
multipart格式(上传头像可)
data:image/s3,"s3://crabby-images/519c2/519c23f771b6d69579554634fd3a78a11e33ffec" alt=""
代码
<template>
<div id="app">
<input type="button" value="简单get" @click="login">
<input type="button" value="token" @click="token">
<input type="button" value="查询字符串带参数" @click="params">
<input type="button" value="配置携带参数" @click="configParams">
<input type="button" value="请求体中的json格式" @click="bodyParams">
<input type="button" value="请求体中的非json格式" @click="bodyParamsNoJson">
<input type="button" value="使用multipart格式" @click="multipartParams">
<input type="button" value="封装axios" @click="getAxios">
</div>
</template>
<script>
import axios from "axios";
const options = {
data: function () {
return {
};
},
methods: {
// 简单get
login: async function () {
const resp = await axios.get("http://localhost:8288/test/compile");
alert(resp.data.data);
localStorage.setItem("token", resp.data.data)
},
// 携带token
token: async function () {
const resp = await axios.post("http://localhost:8288/test/token", {}, {
headers: {
"token": localStorage.getItem("token")
}
})
alert(resp.data.data);
},
// 携带参数在查询字符串中
params: async function () {
const name = encodeURIComponent("张三")
const age = 12
const resp = await axios.post(`http://localhost:8288/test/params?name=${name}&age=${age}`, {}, {})
alert(resp.data.data);
},
// 携带参数在配置中
configParams: async function () {
const name = "张三"
const age = 12
const resp = await axios.post(`http://localhost:8288/test/params`, {}, {
params:{
name: name,
age: age
}
})
alert(resp.data.data);
},
// 请求体中传参,参数默认是json格式
bodyParams: async function () {
const name = "张三"
const age = 12
const resp = await axios.post(`http://localhost:8288/test/params`, {
name: name,
age: age
}, {})
alert(resp.data.data);
},
// 请求体中传参,不用json
bodyParamsNoJson: async function () {
const params = new URLSearchParams()
params.append("name", "往往")
params.append("age", 28)
const resp = await axios.post(`http://localhost:8288/test/params`, params, {})
alert(resp.data.data);
},
// 使用multipart格式---上传头像
multipartParams: async function () {
const params = new FormData()
params.append("name", "lisi")
params.append("age", 11)
const resp = await axios.post(`http://localhost:8288/test/params`, params, {})
alert(resp.data.data);
},
// 封装axios--不可用
getAxios: async function () {
const _axios = axios.create({
baseURL: "http://localhost:8288",
withCredentials: true, // 允许携带token
})
const params = new URLSearchParams()
params.append("name", "往往")
params.append("age", 28)
const resp = await _axios.post(`/test/paramsToken`, params, {
headers: {
"token":"111"
}
})
alert(resp.data.data);
},
},
computed: {
}
};
export default options;
</script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
}
nav {
padding: 30px;
}
nav a {
font-weight: bold;
color: #2c3e50;
}
nav a.router-link-exact-active {
color: #42b983;
}
</style>
响应数据
data:image/s3,"s3://crabby-images/96bdf/96bdf4f3c51c6c95aeea183b0d59aa73f288a25a" alt=""
条件渲染
if-else
data:image/s3,"s3://crabby-images/09835/09835d65a443fada5bbb074d82d8fad879df144e" alt=""
代码
<template>
<div id="app">
<div v-if="problems.length > 0">显示数据</div>
<div v-else>不显示</div>
</div>
</template>
<script>
const options = {
data: function () {
return {
problems: [
{id: 1, title: "A+B1", level: "easy"},
{id: 2, title: "A+B2", level: "easy"},
{id: 3, title: "A+B3", level: "easy"},
{id: 4, title: "A+B4", level: "easy"},
]
};
},
methods: {
},
computed: {
}
};
export default options;
</script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
}
nav {
padding: 30px;
}
nav a {
font-weight: bold;
color: #2c3e50;
}
nav a.router-link-exact-active {
color: #42b983;
}
</style>
列表渲染
for
data:image/s3,"s3://crabby-images/e3bd9/e3bd9445223dc995e4b238993fcd941b23f86f92" alt=""
代码
<template>
<div id="app">
<div v-if="problems.length > 0">
<div class="row" v-for="problem of problems" :key="problem.id">
<span>{{problem.id}} </span>
<span>{{problem.title}} </span>
<span>{{problem.level}} </span>
</div>
</div>
<div v-else>不显示</div>
</div>
</template>
<script>
const options = {
data: function () {
return {
problems: [
{id: 1, title: "A+B1", level: "easy"},
{id: 2, title: "A+B2", level: "easy"},
{id: 3, title: "A+B3", level: "easy"},
{id: 4, title: "A+B4", level: "easy"},
]
};
},
methods: {
},
computed: {
}
};
export default options;
</script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
}
nav {
padding: 30px;
}
nav a {
font-weight: bold;
color: #2c3e50;
}
nav a.router-link-exact-active {
color: #42b983;
}
</style>
页面加载就执行方法
data:image/s3,"s3://crabby-images/76ea1/76ea135ed6bcfa36a1483dd08dc3c9c2f7b553d8" alt=""
组件复用
创建组件
data:image/s3,"s3://crabby-images/eca35/eca35d73ccec2962959ab9cb0f8e02c3f4d6dec1" alt=""
导入组件
data:image/s3,"s3://crabby-images/25596/255960254605770a1d8defe85ac72cd09bebc431" alt=""
使用组件
data:image/s3,"s3://crabby-images/25596/255960254605770a1d8defe85ac72cd09bebc431" alt=""
代码
<template>
<div id="app">
<my-button></my-button>
</div>
</template>
<script>
import MyButton from '@/components/ExamplyView.vue'
const options = {
data: function () {
return {
};
},
components: {
MyButton,
},
mounted() { // 组件加载就执行
},
methods: {
},
computed: {
}
};
export default options;
</script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
}
nav {
padding: 30px;
}
nav a {
font-weight: bold;
color: #2c3e50;
}
nav a.router-link-exact-active {
color: #42b983;
}
</style>
组件插槽
data:image/s3,"s3://crabby-images/60296/60296dffa5d29207f36ce745515c8214456cde9f" alt=""
data:image/s3,"s3://crabby-images/210d3/210d3c95d68c619d973ace14dfd8b907309d9f2c" alt=""
自定义化组件
类似于参数传参
子组件
data:image/s3,"s3://crabby-images/3cfc3/3cfc32fe04d1dfc379fa61afb0c0c73a0fabcce3" alt=""
父组件
data:image/s3,"s3://crabby-images/65bc2/65bc2b1bea66123a719ee91a43696ef1e4a09e91" alt=""
四、Element-UI
安装ElementUI
npm install element-ui -S
引入ElementUI
data:image/s3,"s3://crabby-images/2385a/2385aa9d28d06a84e0ee21b78c7372bb9eb81707" alt=""
import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'
import Element from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
Vue.use(Element)
Vue.config.productionTip = false
new Vue({
router,
store,
render: h => h(App)
}).$mount('#app')
表格
data:image/s3,"s3://crabby-images/acd4b/acd4b35c6cb865b61eebc947fa022f3d9e2d82a4" alt=""
data:image/s3,"s3://crabby-images/88e66/88e6696d9e6786e28d859fdb9b4e9e2972c752d4" alt=""
<template>
<div id="app">
<el-table :data="problems">
<el-table-column label="序号" prop="id"></el-table-column>
<el-table-column label="题目" prop="title"></el-table-column>
<el-table-column label="难点" prop="level"></el-table-column>
</el-table>
</div>
</template>
<script>
import MyButton from '@/components/ExamplyView.vue'
const options = {
data: function () {
return {
problems: [
{id: 1, title: "A+B1", level: "easy"},
{id: 2, title: "A+B2", level: "easy"},
{id: 3, title: "A+B3", level: "easy"},
{id: 4, title: "A+B4", level: "easy"},
]
};
},
components: {
MyButton,
},
mounted() { // 组件加载就执行
},
methods: {
},
computed: {
}
};
export default options;
</script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
}
nav {
padding: 30px;
}
nav a {
font-weight: bold;
color: #2c3e50;
}
nav a.router-link-exact-active {
color: #42b983;
}
</style>
分页
静态页面
data:image/s3,"s3://crabby-images/926b9/926b9dadfa98881c13a559673266c15f552522ef" alt=""
事件绑定
data:image/s3,"s3://crabby-images/86156/861567e57387d9f41540aed35153dfa6cd3b4ec3" alt=""
data:image/s3,"s3://crabby-images/070c7/070c7c093022f8259aa7ca0e419a7dd04c9064a5" alt=""
代码
<template>
<div id="app">
<el-table :data="problems">
<el-table-column label="序号" prop="id"></el-table-column>
<el-table-column label="题目" prop="title"></el-table-column>
<el-table-column label="难点" prop="level"></el-table-column>
</el-table>
<el-pagination
:total="problems.length"
:page-size="pageSize"
:current-page="currentPage"
layout="prev, pager, sizes, next, ->, total"
:page-sizes="pageSizes"
@current-change="currentChange"
@size-change="sizeChange">
</el-pagination>
</div>
</template>
<script>
import MyButton from '@/components/ExamplyView.vue'
const options = {
data: function () {
return {
problems: [
{id: 1, title: "A+B1", level: "easy"},
{id: 2, title: "A+B2", level: "easy"},
{id: 3, title: "A+B3", level: "easy"},
{id: 4, title: "A+B4", level: "easy"},
{id: 5, title: "A+B4", level: "easy"},
{id: 6, title: "A+B4", level: "easy"},
{id: 7, title: "A+B4", level: "easy"},
],
pageSize: 2,
currentPage: 1,
pageSizes: [2, 4]
};
},
components: {
MyButton,
},
mounted() { // 组件加载就执行
},
methods: {
currentChange: function (page) {
// 页面改变 发起请求获取分页数据
this.currentPage = page;
alert(page + ":" + this.pageSize)
},
sizeChange: function(size) {
// 页面展示数据条数改变 发起请求获取数据
this.pageSize = size;
alert(this.currentPage + ":" + size)
}
},
computed: {
}
};
export default options;
</script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
}
nav {
padding: 30px;
}
nav a {
font-weight: bold;
color: #2c3e50;
}
nav a.router-link-exact-active {
color: #42b983;
}
</style>
表格+分页+搜索小demo
<template>
<div id="app">
<el-input size="mini" placeholder="请输入题目" style="width: 300px;" v-model="queryVo.title" clearable></el-input>
<el-select placeholder="选择题号" size="mini" style="margin-left: 20px" v-model="queryVo.ids" clearable>
<div v-for="problem in problems" :key="problem.id">
<el-option :value="problem.id"></el-option>
</div>
</el-select>
<el-button size="mini" type="primary" style="margin-left: 20px" @click="query">提交</el-button>
<el-divider></el-divider>
<el-table :data="problems">
<el-table-column label="序号" prop="id"></el-table-column>
<el-table-column label="题目" prop="title"></el-table-column>
<el-table-column label="难点" prop="level"></el-table-column>
</el-table>
<el-pagination
:total="problems.length"
:page-size="pageSize"
:current-page="currentPage"
layout="prev, pager, sizes, next, ->, total"
:page-sizes="pageSizes"
@current-change="currentChange"
@size-change="sizeChange">
</el-pagination>
</div>
</template>
<script>
import MyButton from '@/components/ExamplyView.vue'
const options = {
data: function () {
return {
queryVo: {
title: "",
ids: []
},
problems: [
{id: 1, title: "A+B1", level: "easy"},
{id: 2, title: "A+B2", level: "easy"},
{id: 3, title: "A+B3", level: "easy"},
{id: 4, title: "A+B4", level: "easy"},
{id: 5, title: "A+B4", level: "easy"},
{id: 6, title: "A+B4", level: "easy"},
{id: 7, title: "A+B4", level: "easy"},
],
pageSize: 2,
currentPage: 1,
pageSizes: [2, 4]
};
},
components: {
MyButton,
},
mounted() { // 组件加载就执行
},
methods: {
currentChange: function (page) {
// 页面改变 发起请求获取分页数据
this.currentPage = page;
alert(page + ":" + this.pageSize)
},
sizeChange: function(size) {
// 页面展示数据条数改变 发起请求获取数据
this.pageSize = size;
alert(this.currentPage + ":" + size)
},
query: function () {
// 根据条件进行查询
alert(this.queryVo.title + ":" + this.queryVo.ids)
}
},
computed: {
}
};
export default options;
</script>
<style>
.input1 {
width: 50px;
}
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
}
nav {
padding: 30px;
}
nav a {
font-weight: bold;
color: #2c3e50;
}
nav a.router-link-exact-active {
color: #42b983;
}
</style>
data:image/s3,"s3://crabby-images/e688f/e688f060a7f01c9f696901e0d4289e9a92afdb01" alt=""
data:image/s3,"s3://crabby-images/9d9d0/9d9d05a0d9b31751f600164a6e6b058ea4b0eaaa" alt=""
data:image/s3,"s3://crabby-images/f75f0/f75f043a65f273077d4af473a6c288bc8122fe27" alt=""
级联选择器
五、Router
路由配置
data:image/s3,"s3://crabby-images/84a3f/84a3f85b83b1a67e1ec3c6e442ef6e1166b931de" alt=""
路由跳转
<router-link to="target"></router-link> // 页面
this.$router.push(url) // js
导航栏案例
六、VueX
vuex
没用到
七、开发
data:image/s3,"s3://crabby-images/5f8d7/5f8d7fed374272af2ae77d6ac834564ad1068046" alt=""