所有课程笔记都是根据学习慕课网《Vue2.5-2.6-3.0 开发去哪儿网App 从零基础入门到实战项目开发》课程学习的总结,希望可以帮助到大家。
1.创建Vue实例
var vm = new Vue({
})
2. data 用于定义属性。
methods 用于定义的函数,可以通过 return 来返回函数值。
{{ }} 用于输出对象属性和函数返回值。
3.插值
数据绑定最常见的形式就是使用 {{…}}(双大括号)的文本插值.
实例
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Hello world</title>
<script src="../vue.js"> <!-- 引入vue库 -->
</script>
</head>
<body>
<div id="app">
{{content}} <!-- 通过{{}}这周方法调用 data里的数据 -->
</div>
<script type="text/javascript">
// var dom = document.getElementById('app');
// dom.innerHTML='Hello world'
var app = new Vue({ //创建vue实例
el:'#app', //第一个参粗el,el配置项指的是实例负责管理的区域,让vue实例去接管id=app的div标签里的所有内容
data:{ //data指的是数据
content:'hello world'
}
})
setTimeout(function(){
app.$data.content = 'bye world' //app代表vue实例,$data指data内的数据,
},2000)
</script>
</body>
</html>
4.完成TodoItem实例
需要掌握的知识:
(1) v-html
Html 使用 v-html 指令用于输出 html 代码.
<div id="app">
<div v-html="message"></div>
</div>
<script>
new Vue({
el: '#app',
data: {
message: '输出的内容'
}
})
</script>
(2)v-bind
HTML 属性中的值应使用 v-bind 指令
<div id="app">
<label for="r1">
修改颜色
</label><input type="checkbox" v-model="use" id="r1">
<br><br>
<div v-bind:class="{'class1': use}">
v-bind:class 指令
</div>
</div>
<script>
new Vue({
el: '#app',
data:{ use: false }
});
</script>
(3)指令
指令是带有 v- 前缀的特殊属性。指令用于在表达式的值改变时,将某些行为应用到 DOM 上。
<div id="app">
<p v-if="seen">现在你看到我了</p>
</div>
<script>
new Vue({
el: '#app',
data: {
seen: true
}
})
</script>
v-if 指令将根据表达式 seen 的值(true 或 false )来决定是否插入 p 元素。
(4)参数
参数在指令后以冒号指明。
<div id="app">
<pre><a v-bind:href="url">菜鸟教程</a></pre>
</div>
<script>
new Vue({
el: '#app',
data: {
url: 'http://www.runoob.com'
}
})
</script>
v-bind 指令将该元素的 href 属性与表达式 url 的值绑定。
(5)v-on 指令
v-on 指令用于监听 DOM 事件:<a v-on:click="doSomething">
在这里参数是监听的事件名。
(6)修饰符
修饰符是以半角句号 .
指明的特殊后缀,用于指出一个指令应该以特殊方式绑定。
(7)v-model
在 input 输入框中我们可以使用 v-model 指令来实现双向数据绑定。
(8)缩写
v-bind:
<!-- 完整语法 -->
<a v-bind:href="url"></a>
<!-- 缩写 -->
<a :href="url"></a>
v-on:
<!-- 完整语法 -->
<a v-on:click="doSomething"></a>
<!-- 缩写 -->
<a @click="doSomething"></a>
TodoItem实例
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script src="../vue.js" type="text/javascript" charset="utf-8"></script>
</head>
<body>
<div id="app">
<input type="text" v-model="inputValue"/>
<button type="button" v-on:click="handleBtnClick">提交</button>
<ul>
<li v-for="item in list">{{item}}</li>
</ul>
</div>
<script type="text/javascript">
var app = new Vue({
el:"#app",
data:{
list:[],
inputValue:''
},
methods:{
handleBtnClick:function(){
this.list.push(this.inputValue),
//push() 方法可向数组的末尾添加一个或多个元素,并返回新的长度。
this.inputValue=''
}
}
})
</script>
</body>
</html>