vue简单构建
html
<div id="app">
{{ message }}
<button v-on:click="change">点击</button>
</div>
JS
<script src="js/vue.js"></script>
<script>
var app = new Vue({
el: '#app',
data: {
message: 'Hello Vue!'
},
methods:{
change:function(){
this.message='hello world!'
}
}
})
</script>
methods 用于定义的函数,可以通过 return 来返回函数值。
{{ }} 用于输出对象属性和函数返回值。
id名称 “app” ,与new Vue()中的el “#app” 相对应
HTML中的 “{{message}}” 与new Vue()中的data的 “message” 相对应
HTML中的 “change” 与new Vue()中的methods的 “change” 方法相对应
Vue.js 模板语法
1、插值,数据绑定最常见的形式就是使用 {{...}}(双大括号)的文本插值包括JS表达式
<p>{{ message }}</p>
{{ number + 1 }}
{{ ok ? 'YES' : 'NO' }}
{{ message.split('').reverse().join('') }}
2、v-text 指令用于输出文本<div v-text="message"></div>
3、v-html 指令用于输出 html 代码<div v-html="message"></div>
4、v-model指令用于实现双向数据绑定
<div id="app">
<p>{{ message }}</p>
<input v-model="message">
<p>单个复选框:</p>
<input type="checkbox" id="checkbox" v-model="checked">
<label for="checkbox">{{ checked }}</label>
<p>多个复选框:</p>
<input type="checkbox" id="runoob" value="Runoob" v-model="checkedNames">
<label for="runoob">Runoob</label>
<input type="checkbox" id="google" value="Google" v-model="checkedNames">
<label for="google">Google</label>
<input type="checkbox" id="taobao" value="Taobao" v-model="checkedNames">
<label for="taobao">taobao</label>
<br>
<span>选择的值为: {{ checkedNames }}</span>
</div>
<script>
new Vue({
el: '#app',
data: {
message: 'Runoob!',
checked : false,
checkedNames: []
}
})
</script>
5、v-cloak 隐藏未编译的标签,通常用来解决{{}}表达式闪烁问题
<style>
[v-cloak]{display:none;}
</style>
<span v-cloak>{{msg}}</span>
6、v-bind 指令用于绑定各种属性,v-bind:
可以简写为:
绑定id
<div v-bind:id="dynamicId"></div>
绑定disabled属性
<button v-bind:disabled="isButtonDisabled">Button</button>
多种方式绑定style和class
<style>
.red{color:red;}
.fs-30{font-size:30px;}
.c-blue{color:blue;}
.classC{color:green;}
.classD{width:100px;border-bottom:1px solid green;}
</style>
<ul id="app">
<li v-bind:src="imageSrc" :style="{'width':'100px'}"></li>
<li v-bind:class="{red:isRed}">red</li>
<li :class="[classA,classB]">blue</li>
<li :class="[classA,{classC:isC;classD:isD}]">green</li>
<li :class="{fontSize:size+'px'}">skyblue</li>
<li :class="[styleObjectA,styleObjectB]">purple</li>
</ul>
<script>
new Vue({
el:"#app",
data:{
imageSrc="./images/1.png",
isRed:true,
classA:'fs-30',
classB:'c-blue',
isC:'true',
isD:'true',
size:'10',
styleObjectA:{
"font-size":"25px",
"color":"red"
},
styleObjectB:{
"width":"150px",
"border-bottom":"1px dashed red"
}
}
})
</script>
7、v-if 指令用于判断,如果seen是true可以看到,如果是false看不到
<p v-if="seen">现在你看到我了</p>
8、v-else与v-else-if,这两个必须用于v-if后面
<div v-if="Math.random() > 0.5">
Sorry
</div>
<div v-else-if="Math.random() <0.8">
a little sorry
</div>
<div v-else>
Not sorry
</div>
9、v-show,与v-if都可以用来显示/隐藏元素<p v-show="seen">现在你看到我了</p>
注意:v-if 为false时,元素不会被渲染;而v-show为false时元素被渲染,只是在元素上增加了
display:none
样式进行隐藏
10、v-on 指令用于绑定各种方法,监听DOM事件,v-on:
可以简写为@
<a v-on:click="doSomething">
11、修饰符,修饰符是以半角句号 .
指明的特殊后缀,用于指出一个指令应该以特殊方式绑定。例如.stop
、.prevent
、.capture
、.self
、.once
等。
.prevent修饰符告诉 v-on 指令对于触发的事件调用 event.preventDefault()
<form v-on:submit.prevent="onSubmit"></form>
<!-- 阻止单击事件冒泡 -->
<a v-on:click.stop="doThis"></a>
<!-- 提交事件不再重载页面 -->
<form v-on:submit.prevent="onSubmit"></form>
<!-- 修饰符可以串联 -->
<a v-on:click.stop.prevent="doThat"></a>
<!-- 只有修饰符 -->
<form v-on:submit.prevent></form>
<!-- 添加事件侦听器时使用事件捕获模式 -->
<div v-on:click.capture="doThis">...</div>
<!-- 只当事件在该元素本身(而不是子元素)触发时触发回调 -->
<div v-on:click.self="doThat">...</div>
<!-- click 事件只能点击一次,2.1.4版本新增 -->
<a v-on:click.once="doThis"></a>
按键修饰符
Vue 允许为 v-on 在监听键盘事件时添加按键修饰符,记住所有的 keyCode 比较困难,所以 Vue 为最常用的按键提供了别名,包括.enter
、.tab
、.delete (捕获 "删除" 和 "退格" 键)
、.esc
、.space
、.up
、.down
、.left
、.right
、.ctrl
、.alt
、.shift
、.meta
<!-- 只有在 keyCode 是 13 时调用 vm.submit() -->
<input v-on:keyup.13="submit">
<input v-on:keyup.enter="submit">
<!-- 缩写语法 -->
<input @keyup.enter="submit">
<!-- Alt + C -->
<input @keyup.alt.67="clear">
<!-- Ctrl + Click -->
<div @click.ctrl="doSomething">Do something</div>
表单修饰符
表单修饰符用于表单输入框.lazy
、.number
、.trim
在默认情况下, v-model 在 input 事件中同步输入框的值与数据,但你可以添加一个修饰符 lazy ,从而转变为在 change 事件中同步,即只有input输入框失去焦点的时候才同步:
<!-- 在 "change" 而不是 "input" 事件中更新 -->
<input v-model.lazy="msg" >
如果想自动将用户的输入值转为 Number 类型(如果原值的转换结果为 NaN 则返回原值),可以添加一个修饰符 number 给 v-model 来处理输入值,type="number" 时 HTML 中输入的值也总是会返回字符串类型。:
<input v-model.number="age" type="number">
如果要自动过滤用户输入的首尾空格,可以添加 trim 修饰符到 v-model 上过滤输入:
<input v-model.trim="msg">
12、过滤器
<div id="app">
{{ message | capitalize }}
</div>
<script>
new Vue({
el: '#app',
data: {
message: 'runoob'
},
filters: {
capitalize: function (value) {
if (!value) return ''
value = value.toString()
return value.charAt(0).toUpperCase() + value.slice(1)
}
}
})
</script>
capitalize是自定义的一个过滤器,将单词首字母变为大写
13、v-for遍历数组和对象
遍历数组
<div id="app">
<ol>
<li v-for="site in sites">
{{ site.name }}
</li>
//<li v-for="(site,index) in sites">{{index}}:{{site}}:{{ site.name }}</li>
</ol>
</div>
<script>
new Vue({
el: '#app',
data: {
sites: [
{ name: 'Runoob' },
{ name: 'Google' },
{ name: 'Taobao' }
]
}
})
</script>
遍历对象
<div id="app">
<ul>
<li v-for="value in object">
{{ value }}
</li>
//<li v-for="(value, key) in object">{{ key }} : {{ value }}</li> key-键名
//<li v-for="(value, key, index) in object">{{ index }}. {{ key }} : {{ value }}</li> index-索引值
</ul>
</div>
<script>
new Vue({
el: '#app',
data: {
object: {
name: '菜鸟教程',
url: 'http://www.runoob.com',
slogan: '学的不仅是技术,更是梦想!'
}
}
})
</script>
v-for 也可以循环整数
<li v-for="n in 10">
{{ n }}
</li>
14、计算属性computed
<div id="app">
<p>原始字符串: <input type="text" v-model="message"/></p>
<p>计算后反转字符串: <input type="text" v-model="reversedMessage"/></p>
</div>
<script>
var vm = new Vue({
el: '#app',
data: {
message: 'Runoob!',
},
computed: {
// 计算属性的 getter
reversedMessage: function () {
// `this` 指向 vm 实例
return this.message.split('').reverse().join('')
}
}
})
</script>
计算属性与methods对比
我们可以使用 methods 来替代 computed,效果上两个都是一样的,但是 computed 是基于它的依赖缓存,只有相关依赖发生改变时才会重新取值。而使用 methods ,在重新渲染的时候,函数总会重新调用执行。
<div id="app">
<p>原始字符串: <input type="text" v-model="message"/></p>
<p>计算后反转字符串: <input type="text" v-model="reversedMessage"/></p>
<button @click="change">反转</button>
</div>
<script>
var vm = new Vue({
el: '#app',
data: {
message: 'Runoob!',
reversedMessage: ''
},
methods: {
change:function(){
this.reversedMessage=this.message.split('').reverse().join('');
}
}
})
</script>
15、$watch监听属性
<div id = "computed_props">
千米 : <input type = "text" v-model = "kilometers">
米 : <input type = "text" v-model = "meters">
</div>
<p id="info"></p>
<script type = "text/javascript">
var vm = new Vue({
el: '#computed_props',
data: {
kilometers : 0,
meters:0
},
methods: {
},
computed :{
},
watch : {
kilometers:function(val) {
this.kilometers = val;
this.meters = val * 1000;
},
meters : function (val) {
this.kilometers = val/ 1000;
this.meters = val;
}
}
});
// $watch 是一个实例方法
vm.$watch('kilometers', function (newValue, oldValue) {
// 这个回调将在 vm.kilometers 改变后调用
document.getElementById ("info").innerHTML = "修改前值为: " + oldValue + ",修改后值为: " + newValue;
})
</script>