1、什么是ES6,ES和JS的关系
2、var、let、const
3、字符串函数
indexOf
lastIndexOf
charAt
substr
substring
concat
includes
startswith
endswith
模板字符串 在这个里面写什么格式,最终就显示什么格式
4、解构表达式:将数组的值或者对象的属性 赋值给 变量
5、函数的简写方式:箭头函数
var print1 = a => a+b
var print2 = (a,b) => { console.log(a); console.log(b) }
6、对象中方法的简写方式
let person = {
name:“xxx”,
eat1:function(food){},
eat2(food){},
eat3: food => {}
}
1 Vue是一个MVVM框架,什么是MVVM,
MVVM是MVC的升级,MVVM比MVC多了一个双向绑定
2 什么是双向绑定?
3、Vue中有哪些指令?
4、Vue生命周期的钩子函数有哪些?
5、什么是js的冒泡事件?(这是问题,得解决)
6、计算属性computed
7、watch监控某个属性的值发生改变的时候,做做件事情
前端开发模式的发展。
静态页面
异步刷新,操作DOM
1995年,网景工程师Brendan Eich 花了10天时间设计了JavaScript语言.
随着JavaScript的诞生,我们可以操作页面的DOM元素及样式,页面有了一些动态的效果,但是依然是以静态为主。
ajax盛行:
MVVM,关注模型和视图–相当于后端的MVC,但是前端的MVVM比MVC强大
2008年,google的Chrome发布,随后就以极快的速度占领市场,超过IE成为浏览器市场的主导者。
2009年,Ryan Dahl在谷歌的Chrome V8引擎基础上,打造了基于事件循环的异步IO框架:Node.js。
node.js的伟大之处不在于让JS迈向了后端开发,而是构建了一个庞大的生态系统。
2010年,NPM作为node.js的包管理系统首次发布,开发人员可以遵循Common.js规范来编写Node.js模块,然后发布到NPM上供其他开发人员使用。目前已经是世界最大的包模块管理系统。
随后,在node的基础上,涌现出了一大批的前端框架:
MVVM模式
在MVVM之前,开发人员从后端获取需要的数据模型,然后要通过DOM操作Model渲染到View中。而后当用户操作视图,我们还需要通过DOM获取View中的数据,然后同步到Model中。
而MVVM中的VM要做的事情就是把DOM操作完全封装起来,开发人员不用再关心Model和View之间是如何互相影响的:
把开发人员从繁琐的DOM操作中解放出来,把关注点放在如何操作Model上。
注:所有的获取页面元素或者给页面元素赋值的操作都是DOM操作
而我们今天要学习的,就是一款MVVM模式的框架:Vue
面试题1:解释一下MVVM?
M:model数据层
V:view视图层
VM:将model层和view层绑定在一起的层,这一层vue已经自动完成好了
面试2:MVC和MVVM的区别是什么?
在MVVM之前,开发人员从后端获取需要的数据模型,然后要通过DOM操作Model渲染到View中。而后当用户操作视图,我们还需要通过DOM获取View中的数据,然后同步到Model中。
而MVVM中的VM要做的事情就是把DOM操作完全封装起来,开发人员不用再关心Model和View之间是如何互相影响的:
Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue 也完全能够为复杂的单页应用提供驱动。
渐进式:
1 我们可以像使用jQuery一样,使用vue – 熟悉vue的基础语法
2 采用node的方式去使用vue --企业级开发模式 – 掌握vue企业级开发模式
前端框架三巨头:Vue.js(155k)、React.js(118k)、AngularJS(45k),vue.js以其轻量易用著称,vue.js和React.js发展速度最快,AngularJS已经是老三,而且还在继续下降。
官网:https://cn.vuejs.org/
参考:https://cn.vuejs.org/v2/guide/
Git地址:https://github.com/vuejs
尤雨溪,Vue.js 创作者,Vue Technology创始人,致力于Vue的研究开发。
总结:
1 vue是一个mvvm框架,就是后端的MVC框架,但是功能更强大
2 vue的最全面的文档是官方文档
3 vue现在很火
接下来,我们快速领略下vue的魅力
创建一个maven工程:
位置信息:
下载地址:https://github.com/vuejs/vue
https://github.com/vuejs/vue/blob/dev/dist/vue.js
可以下载2.6.10版本https://github.com/vuejs/vue/archive/v2.6.10.zip
下载解压,得到vue.js文件。
或者也可以直接使用公共的CDN服务:
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js">script>
或者:
<script src="https://cdn.jsdelivr.net/npm/vue">script>
在vue-demo目录新建一个HTML
在hello.html中,我们编写一段简单的代码:
h2中要输出一句话:xx 非常帅。效果图如下所示:
然后我们通过Vue进行渲染:
<!-- 引入vue -->
<script src="vue-2.6.10.js"></script>
<!-- 1 必须要有父容器,所有内容只能写在这个父容器中
父容器一定要有id属性,id的值自定义,但是一般叫 app
-->
<div id="app">
<!-- 此处需要获取Vue对象中的name
{{}}两个大括号获取data中的属性的值
-->
<h2>{{name}}很帅</h2>
<h2>有{{num}}位女神为之倾倒</h2>
</div>
<!-- 通过vue控制x显示的内容 -->
<script>
// 方向一:当改变data.属性内容的时候,view中自动更新
// 方向二:当在页面改变name的时候,data中的name也会自动更新
var vm = new Vue({
el:"#app",//el就是element的简写,指向父容器的id
data:{// data 专门用来存放数据
name:"奇哥",
num:100
}
});
</script>
h2
元素中,我们通过{{name}}的方式,来渲染刚刚定义的name属性。打开页面查看效果:
更神奇的在于,当你修改name属性时,页面会跟着变化:
方向一:当改变data中的属性的值,页面也会发生改变
方向二:当改变页面 文本框内容 的时候,data中的值也会自动改变
input文本框
我们对刚才的案例进行简单修改:
<div id="app">
<input type="text" v-model="num">
<h2>
{{name}} 非常帅,
有{{num}}位女神为他着迷。
h2>
div>
<script src="vue-2.6.10.js">script>
<script type="text/javascript">
// 生成一个Vue实例
var app = new Vue({
el:"#app", // el,即element。要渲染的的页面元素
data:{ // 数据
name:"奇哥",
num:1
}
})
script>
num
input
元素,通过v-model
与num
进行绑定。{{num}}
在页面输出效果:
我们可以观察到,输入框的变化引起了data中的num的变化,同时页面输出也跟着变化。
{{num}}
与数据num绑定,因此num值变化,引起了页面效果变化。没有任何dom操作,这就是双向绑定的魅力。
我们在页面添加一个按钮:
<input type="button" value="+" v-on:click="num++">
<input type="button" value="-" v-on:click="num--">
v-on
指令绑定点击事件,而不是普通的onclick
,然后直接操作num效果:
每个 Vue 应用都是通过用 Vue
函数创建一个新的 Vue 实例开始的:
var vm = new Vue({
// 选项
})
在构造函数中传入一个对象,并且在对象中声明各种Vue需要的数据和方法,包括:
等等
接下来我们一 一介绍。
每个Vue实例都需要关联一段Html模板,Vue会基于此模板进行视图渲染。
我们可以通过el属性来指定。
例如一段html模板:
<div id="app">
div>
然后创建Vue实例,关联这个div
var vm = new Vue({
el:"#app"
})
这样,Vue就可以基于id为app
的div元素作为模板进行渲染了。在这个div范围以外的部分是无法使用vue特性的。
当Vue实例被创建时,它会尝试获取在data中定义的所有属性,用于视图的渲染,并且监视data中的属性变化,当data发生改变,所有相关的视图都将重新渲染,这就是“响应式“系统。
html:
<div id="app">
<input type="text" v-model="name"/>
div>
js:
var vm = new Vue({
el:"#app",
data:{
name:"刘德华"
}
})
input
的值Vue实例中除了可以定义data属性,也可以定义方法,并且在Vue的作用范围内使用。
html:
<div id="app">
{{num}}
<button v-on:click="add">加button>
div>
js写法一:
<div id="app">
{{num}}
<button v-on:click="add">加</button>
</div>
<script src="vue-2.6.10.js"></script>
<script>
var vm = new Vue({
el:"#app",
data:{
num:0
},
methods:{
add:function(){
this.num++;
}
}
});
</script>
js写法二:
<div id="app">
{{num}}
<button v-on:click="add">加</button>
</div>
<script src="vue-2.6.10.js"></script>
<script>
var vm = new Vue({
el:"#app",
data:{
num:0
},
methods:{
add(){
this.num++;
}
}
});
</script>
回顾:servlet的生命周期–生老病死
每个 Vue 实例在被创建时都要经过一系列的初始化过程 :创建实例,装载模板,渲染模板等等。Vue为生命周期中的每个状态都设置了钩子函数(监听函数)。每当Vue实例处于不同的生命周期时,对应的函数就会被触发调用。
生命周期:
生命周期的流程:–每个流程对应一个函数,当vue处于某个阶段的时候,会自动触发该阶段的函数
1 初始化前 --BeforeCreate
2 初始化完成 —发送ajax --created
3 双向数据绑定前/挂载前 —BeforeMount
4 双向数据绑定完成/挂载完成 --Mounted
5 更新前 --BeforeUpdate
6 更新完成–updated
7 销毁前–BeforeDestroy
8 销毁完成–Destroyed
我们可以在Vue中定义一个created函数,代表这个时期的构造函数:
html:
<div id="app">
{{hello}}
div>
js:
<script src="vue-2.6.10.js"></script>
<script>
var vm = new Vue({
el:"#app",
data:{
hello:''
},
created(){
this.hello = 'czdx,一统江湖,千秋万代'
}
});
</script>
结果:
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Titletitle>
head>
<body>
<script src="vue-2.6.10.js">script>
<div id="app">
{{msg}}
div>
<script>
var vm = new Vue({
el:"#app",
data:{
msg:'传智大学,一统江湖,千秋万代'
},
methods:{
},
// 创建前
beforeCreate(){
showData("创建前",this);
},
created(){
showData("创建完成",this);
},
// 双向数据绑定前
beforeMount(){
showData("双向数据绑定前",this)
},
// 双向数据绑定完成
mounted(){
showData("双向数据绑定完成",this)
},
beforeUpdate(){
showData("更新前",this)
},
updated(){
showData("更新完成",this)
},
beforeDestroy(){
showData("销毁前",this)
},
destroyed(){
showData("销毁完成",this)
}
});
// 打印 "创建前" 这几个字
// 打印msg的值
// 打印 页面id=app的div中的内容
// 第一个参数:创建前 创建完成 销毁前 销毁后 ......
function showData(process,obj){
console.log(process);
console.log(obj.msg);
console.log(document.getElementById("app").innerHTML)
console.log("----------------------------------")
}
// 更新数据
//vm.msg="good. good study day day up."
// 销毁数据
vm.$destroy();
script>
body>
html>
总结:
1 vue的生命过程很丰富的,每个过程都有要完成的事情
2 created的生命周期:vue已经创建完成,数据已经有了—>通过ajax向后台
往后操作就是进行双向数据绑定
我们可以看下在vue内部的this变量是谁,我们在created的时候,打印this
var vm = new Vue({
el:"#app",
data:{
hello: '' // hello初始化为空
},
created(){
this.hello = "czdx,一统江湖,千秋万代";
console.log(this);
}
})
控制台的输出:
总结:
this就是代表当前的vue对象
什么是指令?
指令 (Directives) 是带有 v-
前缀的特殊特性。指令特性的预期值是:单个 JavaScript 表达式。指令的职责是,当表达式的值改变时,将其产生的连带影响,响应式地作用于 DOM。
例如我们在入门案例中的v-model、v-on…,都是指令。
格式:
{{表达式}}
说明:
示例:
HTML:
<div id="app">{{name}}div>
JS:
var app = new Vue({
el:"#app",
data:{
name:"奇哥"
}
})
使用{{}}方式在网速较慢时会出现问题。在数据未加载完成时,页面会显示出原始的{{}}
,加载完毕后才显示正确数据,我们称为插值闪烁。
我们将网速调慢一些,然后试试看刚才的案例:
刷新页面:
使用v-text和v-html指令来替代{{}}
作用:用来进行数据呈现的,可以代替{{}},可以有效的解决插值表达式的闪烁问题
说明:
示例:
HTML:
<div id="app">
<span v-text="hello">span><br>
<span v-html="hello">span>
div>
JS:
var vm = new Vue({
el:"#app",
data:{
hello:'大家好,我是奇哥'
}
});
效果:
并且不会出现插值闪烁,当没有数据时,会显示空白。
刚才的插值表达式、v-text和v-html可以看做是单向绑定,数据影响了视图渲染,但是反过来就不行。接下来学习的v-model是双向绑定,视图(View)和模型(Model)之间会互相影响。
既然是双向绑定,一定是在视图中可以修改数据,这样就限定了视图的元素类型。目前v-model的可使用元素有:
基本上除了最后一项,其它都是表单的输入项。
Html:
{{num}}
效果:
html:
<div id="app">
<input type="checkbox" v-model="language" value="Java" />Java<br/>
<input type="checkbox" v-model="language" value="PHP" />PHP<br/>
<input type="checkbox" v-model="language" value="Swift" />Swift<br/>
<h1>
你选择了:{{language.join(',')}}
h1>
div>
<script src="./node_modules/vue/dist/vue.js">script>
<script type="text/javascript">
var vm = new Vue({
el:"#app",
data:{
language: []
}
})
script>
CheckBox
对应一个model时,model的类型是一个数组,单个checkbox值是boolean类型input
和textarea
默认对应的model是字符串select
单选对应字符串,多选对应也是数组效果:
html:
男
女
{{sex}}
效果:
html:
<div id="app">
<input type="radio" value="male" v-model="sex">男
<input type="radio" value="female" v-model="sex">女
<h2>{{sex}}h2>
<textarea v-model="sex">textarea>
div>
<script src="vue-2.6.10.js">script>
<script>
var vm = new Vue({
el:"#app",
data:{
sex:'male'
}
});
script>
效果:
html:
<div id="app">
<input type="radio" value="male" v-model="sex">男
<input type="radio" value="female" v-model="sex">女
<h2>{{sex}}h2>
<textarea v-model="sex">textarea><br>
<select v-model="favor">
<option v-for="item in items" :value="item">{{item}}option>
select>
div>
<script src="vue-2.6.10.js">script>
<script>
var vm = new Vue({
el:"#app",
data:{
sex:'male',
favor:'弹琴',
items:['唱歌','跳舞','弹琴']
}
});
script>
效果:
v-on指令用于给页面元素绑定事件。语法:
v-on:事件名="js片段或函数名"
示例:
<div id="app">
<button v-on:click="num++">增加button><br/>
<button v-on:click="decrement">减少button><br/>
<h1>num: {{num}}h1>
div>
<script src="vue-2.6.10.js">script>
<script type="text/javascript">
var app = new Vue({
el:"#app",
data:{
num:1
},
methods:{
decrement(){
this.num--;
}
}
})
script>
效果:
另外,事件绑定可以简写,例如v-on:click='add'
可以简写为@click='add'
表示键盘按下事件。
http://tool.oschina.net/commons?type=4
ascii码
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Titletitle>
head>
<body>
<script src="vue-2.6.10.js">script>
<div id="app">
<input type="text" v-model="name" v-on:keydown="show($event)">
div>
<script>
new Vue({
el:"#app",
data:{
name:""
},
methods:{
show(e){
var keyCode = e.keyCode;
console.log(keyCode)
}
}
})
script>
body>
html>
鼠标移入和移出事件区域事件
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Titletitle>
head>
<body>
<script src="vue-2.6.10.js">script>
<div id="app">
<div style="width: 100px;height: 100px; border: 1px solid red" @mouseover="show()" @mouseout="go()">
div>
div>
<script>
new Vue({
el:"#app",
data:{
name:""
},
methods:{
show(){
console.log("进来了")
},
go(){
console.log("出来了")
}
}
})
script>
body>
html>
概念:
当事件发生后,这个事件就要开始传播(从里到外或者从外向里),会触发所有父层或者子层的方法
案例:
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Titletitle>
head>
<body>
<script src="vue-2.6.10.js">
script>
<div id="app">
<div style="width: 100px;height: 100px; border: red 1px dashed"
@mouseover="over()" @mouseout="out()">
<textarea @mouseover="myover($event)">textarea>
div>
div>
<script>
var vm = new Vue({
el:"#app",
methods:{
over(){
console.log("进来了")
},
out(){
console.log("出去了")
},
myover(e){
console.log("进入txt了");
// js中冒泡的解决方案
// 阻止事件的传播行为
e.stopPropagation();
}
}
});
script>
body>
html>
Vue.js 为 v-on 提供了事件修饰符来处理 DOM 事件细节,如:event.preventDefault() 或event.stopPropagation()。
Vue.js通过由点(.)表示的指令后缀来调用修饰符。
.stop // 停止触发,阻止冒泡修饰符
.prevent // 阻止事件发生,阻止事件默认行为
.capture // 捕获
.self //只点自己身上才运行
.once // 只执行一次
案例1:
案例2:
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Titletitle>
head>
<body>
<script src="vue-2.6.10.js">script>
<div id="app">
<form @submit.prevent action="http://www.czxy.com">
<input type="submit" value="提交">
form>
div>
<script>
new Vue({
el:"#app",
data:{
name:""
},
methods:{
}
})
script>
body>
html>
Vue 允许为 v-on 在监听键盘事件时添加按键修饰符
全部的按键别名:
.enter // 表示键盘的enter键
.tab
.delete (捕获 "删除" 和 "退格" 键)
.esc
.space
.up
.down
.left
.right
.ctrl
.alt
.shift
.meta
案例:
<script src="vue-2.6.10.js"></script>
<div id="app">
<!-- 随意按什么键都显示ascii码 -->
<input type="text" @keydown="show($event)">
<br>
<!-- 判断是否是enter键 -->
<input type="text" @keydown.13="show($event)"><br>
<!-- 判断是否是enter键 -->
<input type="text" @keydown.enter="show($event)">
</div>
<script>
var vm = new Vue({
el:"#app",
methods:{
show(e){
console.log(e.keyCode)
}
}
});
</script>
作业1:只允许文本框中输入0-9数字
遍历数据渲染页面是非常常用的需求,Vue中通过v-for指令来实现。
语法:
v-for="item in items"
示例:ul显示
<div id="app">
<ul>
<li v-for="user in users">
{{user.name}} : {{user.gender}} : {{user.age}}
li>
ul>
div>
<script src="vue-2.6.10.js">script>
<script>
var vm = new Vue({
el:"#app",
data:{
users:[
{name:"张三",gender:"男",age:21},
{name:"李四",gender:"男",age:22},
{name:"王二",gender:"女",age:23},
{name:"赵六",gender:"男",age:24},
{name:"孙七",gender:"男",age:25}
]
}
});
script>
效果:
示例:表格显示
html代码:
姓名
性别
年龄
{{user.name}}
{{user.gender}}
{{user.age}}
效果:
在遍历的过程中,如果我们需要知道数组角标,可以指定第二个参数:
语法
v-for="(item,index) in items"
示例
<div id="app">
<ul>
<li v-for="(user,index) in users">
{{index}} - {{user.name}} : {{user.gender}} : {{user.age}}
li>
ul>
div>
效果:
共同点:都是条件判断
v-if:移除元素
v-show:只是简单的加display:none
v-if,顾名思义,条件判断。当得到结果为true时,所在的元素才会被渲染。
语法:
v-if="布尔表达式"
示例:
<script src="vue-2.6.10.js">script>
<div id="app">
<input type="button" @click="show = !show" value="点我切换">
<h1 v-if="show">
你好
h1>
div>
<script>
new Vue({
el:"#app",
data:{
show:true
},
methods:{
}
})
script>
效果:
当v-if和v-for出现在一起时,v-for优先级更高。也就是说,会先遍历,再判断条件。
示例:筛选出所有性别为女的人
<script src="vue-2.6.10.js">script>
<div id="app">
<ul>
<li v-for="(user,index) in users" v-if="user.gender==='女'">
{{index}} - {{user.name}} : {{user.gender}} : {{user.age}}
li>
ul>
div>
<script>
new Vue({
el:"#app",
data:{
users:[{name:"tom",gender:"男",age:21},
{name:"meiei",gender:"男",age:21},
{name:"lily",gender:"女",age:21},
{name:"jack",gender:"男",age:21},
{name:"lucy",gender:"女",age:21}
]
},
methods:{
}
})
script>
效果:
你可以使用 v-else
指令来表示 v-if
的“else 块”:
Now you see me
Now you don't
v-else
元素必须紧跟在带 v-if
或者 v-else-if
的元素的后面,否则它将不会被识别。
v-else-if
,顾名思义,充当 v-if
的“else-if 块”,可以连续使用:
A
B
C
Not A/B/C
类似于 v-else
,v-else-if
也必须紧跟在带 v-if
或者 v-else-if
的元素之后。
另一个用于根据条件展示元素的选项是 v-show
指令。用法大致一样:
Hello!
不同的是带有 v-show
的元素始终会被渲染并保留在 DOM 中。v-show
只是简单地切换元素的 CSS 属性 display
。
示例:
<div id="app">
<button v-on:click="show = !show">点击切换button><br/>
<h1 v-if="show">
你好
h1>
div>
<script src="vue-2.6.10.js">script>
<script type="text/javascript">
var app = new Vue({
el:"#app",
data:{
show:true
}
})
script>
代码:
页面的HTML标签有很多属性,如果属性想获取vue中的data的值,怎么处理?
假如我们想动态的修改页面元素的属性,比如class属性,这样写是错误的:
<div class="{{mystyle}}">div>
因为插值表达式不能用在属性的值中。
案例:
传智大学
传智大学
传智大学
课堂代码:
<script src="vue-2.6.10.js"></script>
<div id="app">
<!--
学习过的指令
v-on
v-model
v-text
v-html
v-for
v-if
v-show
v-else
{{}}
-->
<!-- 对于属性的值,插值表达式是无法获取的 -->
<!--错误的方式:<a href="{{url}}">百度</a><br>-->
正确的方式:<a v-bind:href="url">百度</a>
<!-- class是标签的属性,属性如何从vue中获取值呢? -->
<div :class="mydiv"></div>
</div>
<script>
var vm = new Vue({
el:"#app",
data:{
url:"http://www.czxy.com",
mydiv:"redDiv"
}
});
</script>
<style type="text/css">
.redDiv{
width: 100px;
height: 100px;
border: 1px solid red;
}
.greenDiv{
width: 100px;
height: 100px;
border: 1px solid green;
}
</style>
v-bind:class
可以简写为:class
<script src="vue-2.6.10.js"></script>
<div id="app">
<!-- 当下拉列表框改变的时候,div的样式要发生改变
也就是要将下拉列表框新选中的样式作用div,也就是将值给mydiv
-->
<select v-model="mydiv">
<!-- value是option的HTML属性 v-for是vue指令,两者能直接互相访问吗?答:不可以 -->
<option v-for="style in myStyles" v-bind:value="style">{{style}}</option>
</select>
<!-- class是标签的属性,属性如何从vue中获取值呢? -->
<div :class="mydiv"></div>
</div>
<script>
var vm = new Vue({
el:"#app",
data:{
mydiv:"redDiv",
myStyles:['redDiv','greenDiv','blackDiv','yellowDiv'],
mySelectValue:''
}
});
</script>
<style type="text/css">
.redDiv{
width: 100px;
height: 100px;
background: red;
}
.greenDiv{
width: 100px;
height: 100px;
background: green;
}
.blackDiv{
width: 100px;
height: 100px;
background: black;
}
.yellowDiv{
width: 100px;
height: 100px;
background: yellow;
}
</style>
在插值表达式中使用js表达式是非常方便的,而且也经常被用到。
但是如果表达式的内容很长,就会显得不够优雅,而且后期维护起来也不方便,例如下面的场景,我们有一个日期的数据,需要显示在页面,默认的显示方式是:
如果只想显示年月日呢?
<body>
<script src="vue-2.6.10.js">script>
<div id="app">
{{birthday.getFullYear() +"-" + birthday.getMonth() + "-" +birthday.getDate()}}
div>
<script>
new Vue({
el:"#app",
data:{
birthday:new Date()
},
methods:{
}
})
script>
虽然能得到结果,但是非常麻烦。
Vue中提供了计算属性,来替代复杂的表达式:
<script src="vue-2.6.10.js"></script>
<div id="app">
您的生日是: {{birth}}
</div>
<script>
new Vue({
el:"#app",
data:{
birthday:new Date()
},
methods:{
},
computed:{
birth(){
return this.birthday.getFullYear() +"-" + this.birthday.getMonth() + "-" +this.birthday.getDate();
}
}
})
</script>
页面使用:
效果:
Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中
axios的github:https://github.com/axios/axios
可以用script引入
引入axios-0.18.0.js
// 为给定 ID 的 user 创建请求
axios.get('/user?ID=12345')
.then(function (response) {
console.log(response);
})
.catch(function (error) {
console.log(error);
});
// 可选地,上面的请求可以这样做
axios.get('/user', {
params: {
ID: 12345
}
}).then(function (response) {
console.log(response);
}).catch(function (error) {
console.log(error);
});
axios.post('/user', {
firstName: 'Fred',
lastName: 'Flintstone'
}).then(function (response) {
console.log(response);
}).catch(function (error) {
console.log(error);
});
为方便起见,为所有支持的请求方法提供了别名
axios.request(config)
axios.get(url[, config])
axios.delete(url[, config])
axios.head(url[, config])
axios.post(url[, data[, config]])
axios.put(url[, data[, config]])
axios.patch(url[, data[, config]])
【需求】:创建data/user.json文件----获取所有用户
使用axios读取user.json文件的内容,并在页面上输出内容。
DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>vuejs中axios数据调用title>
<script src="vue-2.6.10.js">script>
<script src="axios-0.18.0.js">script>
head>
<body>
<div id="app">
{{message}}
div>
body>
<script>
var vm = new Vue({
el: "#app",
data: {
message: ''
},
methods: {
init: function(){
axios.get("./data/user.json").then(function(response){
// alert(response);
alert(JSON.stringify(response))
alert(response.data[0].username);
})
}
},
created: function(){
this.init();
}
});
script>
html>
创建data目录,创建user.json
[
{"username":"张三","age":22},
{"username":"李四","age":21},
{"username":"王五","age":20},
{"username":"赵六","age":23}
]
<head>
<meta charset="UTF-8">
<title>Titletitle>
<script src="../vue-2.6.10.js">script>
head>
<body>
<div id="app">
div>
<script>
var vm = new Vue({
el:"#app",
data:{
users:[],// 定义数组
user:{},//定义对象
username:'',//定义string类型的属性
num:10// 定义int类型的属性
},
methods:{
},
created(){
},
//计算属性
computed:{
}
})
script>