在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
1. Vue概述
可以使用其中的一个或者多个
2. Vue的基本使用2.1 传统开发模式对比//原生JS <div id="msg"></div> <script type="text/javascript"> var msg = 'Hello World' var div = document.querySelector('#msg'); div.innerHTML = msg </script> //jQuery <div id="msg"></div> <script type="text/javascript" src="js/jquery.js"></script> <script type="text/javascript"> var msg = 'Hello World'; $('#msg').html(msg); </script> 2.2 Vue.js之HelloWorld基本步骤引入Vue的方法: 1.下载Vue.js,然后在 2.使用CDN方法。
1、需要提供标签用于填充数据 2、引入Vue.js库文件 3、可以使用vue的语法做功能了 4、把vue提供的数据填充到标签里面 //1.HelloWorld.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> </head> <body> <div id="app"> //插值表达式 <div>{{num}}</div> <div><button @click='handle'>点击</button></div> </div> //引入vue <script type='text/javascript' src='js/vue.js'></script> <script type='text/javascript'> var vm = new Vue({ el: '#app', data: { num: 0 }, methods: { handle: function () { this.num++; } } }); </script> </body> </html> 2.3 Vue.js之HelloWorld细节分析1. 实例参数分析
2.插值表达式用法
3. Vue代码运行原理分析 概述编译过程的概念(Vue语法经过Vue框架编译成原生JS语法,才能够被浏览器执行) 3. Vue 模板语法3.1 模板语法概述
缺点:不同开发人员的代码风格差别很大,随着业务的复杂,后期的维护变得逐渐困难起来。
优点:大家都遵循同样的规则写代码,代码可读性明显提高了,方便后期的维护。 缺点:没有专门提供事件机制。
<div id="app"> <!-- this 指向 vm --> <p> {{ msg }} </p> </div> <script> var vm = new Vue({ el: ‘#app', data: { msg: 'hello vue.js' } }) </script>
3.2 指令1.什么是指令?
2.v-cloak指令用法 插值表达式存在的问题:“闪动” 如何解决该问题:使用v-cloak指令 v-cloak指令的用法 1、提供样式 属性选择器 [v-cloak]{ display: none; } 2、在插值表达式所在的标签中添加v-cloak指令 背后的原理:先通过样式隐藏内容,然后在内存中进行值的替换,替换好之后再显示最终的结果 //02-指令v-cloak的用法.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style type="text/css"> [v-cloak]{ display: none; } </style> </head> <body> <div id="app"> <div v-cloak>{{msg}}</div> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var app = new Vue({ el: '#app', data: { msg: 'Hello Vue' } }); </script> </body> </html> 3 .数据绑定指令
用于将数据填充到标签中,作用于插值表达式类似,但是没有闪动问题
用于将HTML片段填充到标签中,但是可能有安全问题
显示原始信息,跳过编译过程(分析编译过程) //03-数据填充相关3个指令用法.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <div>{{msg}}</div> <div v-text='msg'></div> <div v-html='msg1'></div> <div v-pre>{{msg}}</div> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { msg: 'Hello Vue', msg1: '<h1>HTML</h1>' } }); </script> </body> </html> 4.数据响应式
html5中的响应式(屏幕尺寸的变化导致样式的变化)
v-once的应用场景:如果显示的信息后续不需要再修改,可以使用v-once提高性能。 //04-指令v-once的用法.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <h2>{{message}}</h2> <h2 v-once>{{message}}</h2> </div> <script> const app = new Vue({ el: "#app", data: { message: "你好啊" } }) </script> </body> </html> 3.3 双向数据绑定1.什么是双向数据绑定? 2.双向数据绑定分析 Vue中使用 v-model只能用于表单类型,就是输入性控件,其他控件不能用,用v-bind <input type='text' v-model='uname'/> //05.双向数据绑定.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <div>{{msg}}</div> <div> <input type="text" v-model='msg'> </div> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> /* 双向数据绑定 1、从页面(用户)到数据 2、从数据到页面 */ var vm = new Vue({ el: '#app', data: { msg: 'Hello Vue' } }); </script> </body> </html> 案例解析:当我们在输入框输入内容时,因为input中的v-model绑定了msg,所以会实时将输入的内容传递给msg,msg发生改变。 当msg发生改变时,因为上面我们使用Mustache语法,将msg的值插入到DOM中,所以DOM会发生响应的改变。 3.MVVM设计思想 MVVM是Model-View-ViewModel的简写。它本质上就是MVC 的改进版。MVVM 就是将其中的View 的状态和行为抽象化,让我们将视图 UI 和业务逻辑分开
在我们前端开发中,通常就是DOM层。主要的作用是给用户展示各种信息。
数据可能是我们固定的死数据,更多的是来自我们服务器,从网络上请求下来的数据。
视图模型层是View和Model沟通的桥梁。 一方面它通过Data Binding(数据绑定),将Model的改变实时的反应到View中 另一方面它通过DOM Listener(DOM监听),当DOM发生一些事件(点击、滚动、touch等)时,可以监听到,并在需要的情况下改变对应的Data。 3.4 事件绑定1.Vue如何处理事件?
在这里doSomething() 是一个函数,可以写在methods的方法中,供该标签调用. <button v-on:click="doSomething">...</button> v-on语法糖(简写形式)@ <input type='button' @click='num++'/> //06-事件基本用法.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <div>{{num}}</div> <div> //4种都可以实现 <button v-on:click='num++'>点击</button> <button @click='num++'>点击1</button> <button @click='handle'>点击2</button> <button @click='handle()'>点击3</button> </div> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { num: 0 }, methods: { handle: function () { // 这里的this是Vue的实例对象 console.log(this === vm) // 在函数中 想要使用data里面的数据 一定要加this this.num++;v } } }); </script> </body> </html> 2.事件函数的调用方式 直接绑定函数名称 <button v-on:click='say'>Hello</button> 调用函数 <button v-on:click='say()'>Hello</button> 3.事件函数参数传递 事件函数参数传递 <button v-on:click='say('hi',$event)'>Hello</button> //07-事件函数传参.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <div>{{num}}</div> <div> <!-- 如果事件直接绑定函数名称,那么默认会传递事件对象作为事件函数的第一个参数 --> <button v-on:click='handle1'>点击1</button> <!-- 2、如果事件绑定函数调用,那么事件对象必须作为最后一个参数显示传递, 并且事件对象的名称必须是$event --> <button v-on:click='handle2(123, 456, $event)'>点击2</button> </div> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { num: 0 }, methods: { handle1: function(event) { console.log(event.target.innerHTML) }, handle2: function(p, p1, event) { console.log(p, p1) console.log(event.target.innerHTML) this.num++; } } }); </script> </body> </html> 4.事件修饰符 .stop 阻止冒泡 <a v-on:click.stop="handle">跳转</a> .prevent阻止默认行为 <a v-on:click.prevent="handle">跳转</a> //08-事件修饰符.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <div>{{num}}</div> <div @click='handle0'> <button @click.stop='handle1'>点击1</button> </div> <div> <a href="http://www.baidu.com" @click.prevent='handle2'>百度</a> </div> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { num: 0 }, methods: { handle0: function () { this.num++; }, handle1: function (event) { // js阻止冒泡 // event.stopPropagation(); }, handle2: function (event) { // js阻止默认行为 // event.preventDefault(); } } }); </script> </body> </html> 未加事件修饰符: 加事件修饰符: 5.按键修饰符 .enter 回车键 <input v-on:keyup.enter='submit'> .delete删除键 <input v-on:keyup.delete='handle'> //09-按键修饰符.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <form action=""> <div> 用户名: <input type="text" v-on:keyup.delete='clearContent' v-model='uname'> </div> <div> 密码:<input type="text" v-on:keyup.enter='handleSubmit' v-model='pwd'> </div> <div> <input type="button" v-on:click='handleSubmit' value="提交"> </div> </form> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> Vue.config.keyCodes.f1 = 113 var vm = new Vue({ el: '#app', data: { uname: '', pwd: '', age: 0 }, methods: { clearContent:function(){ // 按delete键的时候,清空用户名 this.uname = ''; }, handleSubmit: function(){ console.log(this.uname,this.pwd) } } }); </script> </body> </html> 6.自定义按键修饰符 全局config.keyCodes 对象 规则:自定义按键修饰符名字是自定义的,但是对应的值必须是按键对应event.keyCode值 Vue.config.keyCodes.f1 = 112 //10-自定义事件修饰符.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> <script type='text/javascript' src='js/vue.js'></script> </head> <body> <div id="app"> <input type="text" @keyup.f1='handle' v-model='msg'> </div> <script type='text/javascript'> Vue.config.keyCodes.f1 = 65 const app = new Vue({ el: "#app", data: { msg: '' }, methods: { handle: function (event) { console.log(event.keyCode); } } }) </script> </body> </html> 案例:简单计算器
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> <script type='text/javascript' src='js/vue.js'></script> </head> <body> <div id="app"> <h2>简单计算器</h2> <div>数值A:<input type="text" v-model="a"></div> <div>数值B:<input type="text" @keyup.enter='Sum' v-model="b"></div> <div><button @click='Sum'>计算</button></div> <div>计算结果:</div> <div v-text='result'></div> </div> <script type='text/javascript'> const app = new Vue({ el: "#app", data: { a: '', b: '', result: '' }, methods: { Sum: function () { //实现计算逻辑 表单输入默认是字符串 加this很重要 this.result = parseInt(this.a) + parseInt(this.b) } } }) </script> </body> </html> 3.5 属性绑定1.Vue如何动态处理属性?
就是一个标签,也是一个标签,我们绑定上的src进行动态赋值。 v-bind指令用法 <a v-bind:href='url'>跳转</a> 缩写形式 <a :href='url'>跳转</a> //12-属性绑定基本用法.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> </head> <body> <div id="app"> <a v-bind:href="url">百度</a> <button @click='handle'>切换</button> </div> <script type='text/javascript' src='js/vue.js'></script> <script type='text/javascript'> const app = new Vue({ el: "#app", data: { url: 'http://www.baidu.com' }, methods: { handle: function () { //修改url地址 this.url = 'http://www.itcast.com' } } }) </script> </body> </html> 2.v-model的低层实现原理分析 不使用v-model也可以实现双向绑定 <input v-bind:value="msg" v-on:input="msg=$event.target.value"> //13-指令v-model的本质.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <div>{{msg}}</div> <input type="text" v-bind:value="msg" v-on:input='handle'> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { msg: 'hello' }, methods: { handle: function(event){ // 使用输入域中的最新的数据覆盖原来的数据 this.msg = event.target.value; } } }); </script> </body> </html> 3.6 样式绑定1. class样式处理 对象语法 <div v-bind:class="{ active: isActive }"></div> 数组语法 <div v-bind:class="[activeClass, errorClass]"></div> //14-样式绑定之class绑定对象用法.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style type='text/css'> .active { border: 1px solid red; width: 100px; height: 100px; } .error { background-color: pink; } </style> </head> <body> <div id="app"> <div :class="{active:isActive,error:isError}">测试样式</div> <button @click='handle'>切换</button> </div> </body> <script type='text/javascript' src='js/vue.js'></script> <script type='text/javascript'> const app = new Vue({ el: "#app", data: { isActive: true, isError: true, }, methods: { handle: function () { //控制isActive在true和false之间切换 this.isActive = !this.isActive this.isError = !this.isError } } }) </script> </html> //15-样式绑定之class绑定数组用法.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style type="text/css"> .active { border: 1px solid red; width: 100px; height: 100px; } .error { background-color: pink; } </style> </head> <body> <div id="app"> <div v-bind:class='[activeClass, errorClass]'>测试样式</div> <button v-on:click='handle'>切换</button> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { activeClass: 'active', errorClass: 'error' }, methods: { handle: function(){ this.activeClass = ''; this.errorClass = ''; } } }); </script> </body> </html> //16-样式绑定之class绑定3个细节用法.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style type="text/css"> .active { border: 1px solid red; width: 100px; height: 100px; } .error { background-color: orange; } .test { color: blue; } .base { font-size: 28px; } </style> </head> <body> <div id="app"> <div v-bind:class='[activeClass, errorClass, {test: isTest}]'>测试样式</div> <div v-bind:class='arrClasses'></div> <div v-bind:class='objClasses'></div> <div class="base" v-bind:class='objClasses'></div> <button v-on:click='handle'>切换</button> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> /* 样式绑定相关语法细节: 1、对象绑定和数组绑定可以结合使用 2、class绑定的值可以简化操作 3、默认的class如何处理?默认的class会保留 */ var vm = new Vue({ el: '#app', data: { activeClass: 'active', errorClass: 'error', isTest: true, arrClasses: ['active','error'], objClasses: { active: true, error: true } }, methods: { handle: function(){ // this.isTest = false; this.objClasses.error = false; } } }); </script> </body> </html> 2. style样式处理 对象语法 <div v-bind:style="{ color: activeColor, fontSize: fontSize }"></div> 数组语法 <div v-bind:style="[baseStyles, overridingStyles]"></div> //17-样式绑定之style绑定用法.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <div v-bind:style='{border: borderStyle, width: widthStyle, height: heightStyle}'></div> <div v-bind:style='objStyles'></div> <div v-bind:style='[objStyles, overrideStyles]'></div> <button v-on:click='handle'>切换</button> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { borderStyle: '1px solid blue', widthStyle: '100px', heightStyle: '200px', objStyles: { border: '1px solid green', width: '200px', height: '100px' }, overrideStyles: { border: '5px solid orange', backgroundColor: 'blue' } }, methods: { handle: function () { this.heightStyle = '100px'; this.objStyles.width = '100px'; } } }); </script> </body> </html> 3.7 分支循环结构1.分支结构
2.v-if与v-show的区别
//18-分支结构.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <div v-if='score>=90'>优秀</div> <div v-else-if='score<90&&score>=80'>良好</div> <div v-else-if='score<80&&score>60'>一般</div> <div v-else>比较差</div> <div v-show='flag'>测试v-show</div> <button v-on:click='handle'>点击</button> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> /*v-show的原理:控制元素样式是否显示 display:none*/ var vm = new Vue({ el: '#app', data: { score: 10, flag: false }, methods: { handle: function(){ this.flag = !this.flag; } } }); </script> </body> </html> 3.循环结构
其中item为自定义属性(改为abc都行),items为需要遍历的数据,index为索引 <li v-for='item in list'>{{item}}</li> <li v-for='(item,index) in list'>{{item}} + '---' +{{index}}</li> key的作用:帮助Vue区分不同的元素对开发功能没有效果,仅仅帮助vue提高性能,要确保key的唯一性 <li :key='item.id' v-for='(item,index) in list'>{{item}} + '---' {{index}}</li> //19-循环结构-遍历数组.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <div>水果列表</div> <ul> <li v-for='item in fruits'>{{item}}</li> <li v-for='(item, index) in fruits'>{{item + '---' + index}}</li> <li :key='item.id' v-for='(item, index) in myFruits'> <span>{{item.ename}}</span> <span>-----</span> <span>{{item.cname}}</span> </li> </ul> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { fruits: ['apple', 'orange', 'banana'], myFruits: [{ id: 1, ename: 'apple', cname: '苹果' },{ id: 2, ename: 'orange', cname: '橘子' },{ id: 3, ename: 'banana', cname: '香蕉' }] } }); </script> </body> </html> 4. 循环结构 v-for遍历对象 <div v-for='(value, key, index) in object'></div> value值 key键 index索引 v-if和v-for结合使用 <div v-if='value==12' v-for='(value, key, index) in object'></div> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <div v-if='v==13' v-for='(value,key,index) in obj'>{{value + '---' + key + '---' + index}}</div> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { obj: { uname: 'zhangsan', age: 13, gender: 'female' } } }); </script> </body> </html> 3.8 v-model、v-on、v-bind使用说明v-model
v-model只能用于表单类型,就是输入性控件,其他控件不能用,用v-bind 一个input标签绑定了msg这个变量,那么只要input输入发生改变,msg的值也就跟着改变,反过来也是一样,这种绑定是双向绑定 <input type='text' v-model='msg'> v-on
当前button绑定鼠标点击事件,点击则调用doSomething方法 <button v-on:click="doSomething">...</button> v-bind
<img :src='msg'> 4. 基础案例:Tab选项卡步骤: 1.实现静态UI效果 用传统的方式实现标签结构和样式 2.基于数据重构UI效果 将静态的结构和样式重构为基于Vue模板语法的形式 处理事件绑定和js控制逻辑 3.声明式编程 模板的结构和最终显示的效果基本一致 //21-选项卡案例.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style type="text/css"> .tab ul { overflow: hidden; padding: 0; margin: 0; } .tab ul li { box-sizing: border-box; padding: 0; float: left; width: 100px; height: 45px; line-height: 45px; list-style: none; text-align: center; border-top: 1px solid blue; border-right: 1px solid blue; cursor } .tab ul li:first-child { border-left: 1px solid blue; } .tab ul li.active { background-color: orange; } .tab div { width: 500px; height: 300px; display: none; text-align: center; font-size: 30px; line-height: 300px; border: 1px solid blue; border-top: 0px; } .tab div.current { display: block; } </style> </head> <body> <div id="app"> <div class="tab"> <ul> <li @click='change(index)' :class='currentIndex==index?"active":""' :key=' item.id' v-for='(item,index) in list'> {{item.title}}</li> </ul> <div :class='currentIndex==index?"current":""' :key='item.id' v-for='(item,index) in list'> <img :src="item.path"> </div> </div> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { currentIndex: 0, //选项卡当前的索引 list: [{ id: 1, title: 'apple', path: 'img/apple.png' }, { id: 2, title: 'orange', path: 'img/orange.png' }, { id: 3, title: 'lemon', path: 'img/lemon.png' } ] }, methods: { change: function (index) { //在这里实现选项卡切换操作:操作类名,通过currentIndex this.currentIndex = index; } } }) </script> </body> </html> 5. Vue常用特性5.1 常用特性概览
5.2 表单操作1.基于Vue的表单操作
//01-表单基本操作.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <title>Document</title> <style type="text/css"> form div { height: 40px; line-height: 40px; } form div:nth-child(4) { height: auto; } form div span:first-child { display: inline-block; width: 100px; } </style> </head> <body> <div id="app"> <form action="http://www.baidu.com"> <div> <span>姓名:</span> <span> <input type="text" v-model="uname" /> </span> </div> <div> <span>性别:</span> <span> <input type="radio" id="male" value="1" v-model="gender" /> <label for="male">男</label> <input type="radio" id="female" value="2" v-model="gender" /> <label for="female">女</label> </span> </div> <div> <span>爱好:</span> <input type="checkbox" id="ball" value="1" v-model="hobby" /> <label for="ball">篮球</label> <input type="checkbox" id="sing" value="2" v-model="hobby" /> <label for="sing">唱歌</label> <input type="checkbox" id="code" value="3" v-model="hobby" /> <label for="code">写代码</label> </div> <div> <span>职业:</span> <select v-model="occupation" multiple> <option value="0">请选择职业</option> <option value="1">教师</option> <option value="2">软件工程师</option> <option value="3">律师</option> </select> </div> <div> <span>个人简介:</span> <textarea v-model="desc"></textarea> </div> <div> <input type="submit" value="提交" @click.prevent="handle" /> </div> </form> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: "#app", data: { uname: "", gender: "", //单选为值 hobby: [""], //多选为数组 occupation: [""], desc: "", }, methods: { handle: function () {}, }, }); </script> </body> </html> 2.表单域修饰符
<input v-model.number='age' type='number' //02-表单域修饰符用法.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <input type="text" v-model.number='age'> <input type="text" v-model.trim='info'> <input type="text" v-model.lazy='msg'> <div>{{msg}}</div> <button @click='handle'>点击</button> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { age: '', info: '', msg: '' }, methods: { handle: function () { console.log(this.age + 1) console.log(this.info.length) } } }); </script> </body> </html> 5.3 自定义指令1.为何需要自定义指令? 内置指令不满足需求 2.自定义指令的语法规则(获取元素焦点) //注册一个全局自定义指令'v-focus' //focus为指令名称 调用时加v- Vue.directive('focus'{ //当被绑定非的元素插入到DOM中时调用 inserted:function(el){ //获取元素的焦点 el.focus() } }) 3.自定义指令用法 <input type="text" v-focus> 一个指令定义对象可以提供如下几个
指令钩子函数会被传入以下参数: e1:指令所绑定的元素,可以用来直接操作DOM. binding:一个对象,包含以下属性:
//03-自定义指令基本用法.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <input type="text" v-focus> <input type="text"> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> Vue.directive('focus', { inserted: function (el) { // el表示指令所绑定的元素 el.focus(); } }); var vm = new Vue({ el: '#app', data: { }, methods: { handle: function () { } } }); </script> </body> </html> 4.带参数的自定义指令(改变元素背景色) Vue.directive('color',{ inserted:function(el,binding){ el.style.backgroundColor =binding.value.color; } }) 5.指令的用法 <input type="text" v-color='{color:'orange'}'> //04-带参数的自定义指令.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> </head> <body> <div id="app"> <input type="text" v-color='msg'> </div> <script type='text/javascript' src='js/vue.js'></script> <script type='text/javascript'> Vue.directive('color', { bind: function (el, binding) { //根据指令的参数设置背景色 el.style.backgroundColor = binding.value.color } }); const app = new Vue({ el: "#app", data: { msg: { color: 'pink' } }, methods: {} }) </script> </body> </html> 6.局部指令:只能在本组件中使用 directives:{ focus:{ //指令的定义 inserted:function(el){ el.focus() } } } <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <input type="text" v-color='msg'> <input type="text" v-focus> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { msg: { color: 'red' } }, methods: { handle: function(){ } }, directives: { color: { bind: function(el, binding){ el.style.backgroundColor = binding.value.color; } }, focus: { inserted: function(el) { el.focus(); } } } }); </script> </body> </html> 5.4 计算属性1.为何需要计算属性? Vue中的 表达式的计算逻辑可能会比较复杂,使用计算属性可以使模板内容更加简介 2.计算属性的用法 computed: { reverseString: function(){ return this.msg.split('').reverse().join(''); } } //06-计算属性基本用法.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <div>{{msg}}</div> <div>{{reverseString}}</div> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { msg: 'nihao' }, computed: { reverseString: function () { //return不要忘记 return this.msg.split('').reverse().join(''); } } }); </script> </body> </html> 3.计算属性和方法的区别
//07-计算属性与方法的区别.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <div>{{reverseString}}</div> <div>{{reverseString}}</div> <div>{{reverseMessage()}}</div> <div>{{reverseMessage()}}</div> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { msg: 'Nihao', num: 100 }, methods: { reverseMessage: function () { console.log('methods') return this.msg.split('').reverse().join(''); } }, computed: { reverseString: function () { console.log('computed') return this.msg.split('').reverse().join(''); } } }); </script> </body> </html> 5.5 侦听器1. 侦听器的应用场景 数据变化时执行异步或开销较大(比较耗时)的操作 2.侦听器的用法 watch: { firstName: function (val) { this.fullName = val + ' ' + this.lastName; }, LastName: function (val) { this.fullName = this.firstName + ' ' + val; }, } //08-侦听器基本用法.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <div> <span>名:</span> <span> <input type="text" v-model='firstName'> </span> </div> <div> <span>姓:</span> <span> <input type="text" v-model='lastName'> </span> </div> <div>{{fullName}}</div> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { firstName: 'Jim', lastName: 'Green', fullName: 'Jin Green' }, watch: { firstName: function (val) { this.fullName = val + ' ' + this.lastName; }, LastName: function (val) { this.fullName = this.firstName + ' ' + val; }, } }); </script> </body> </html> 案例:验证用户名是否可用 需求:输入框中输入姓名,失去焦点时验证是否存在,如果已经存在,提示从新输入,如果不存在,提示可以用。 需求分析:
侦听器 1、采用侦听器监听用户名的变化 2、调用后台接口进行验证 3、根据验证的结果调整提示信息 //09-侦听器案例.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <div> <span>用户名:</span> <span> <input type="text" v-model.lazy='uname'> </span> <span>{{tip}}</span> </div> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> var vm = new Vue({ el: '#app', data: { uname: '', tip: '' }, methods: { checkName: function (uname) { //调用接口,但是可以使用定时任务的方式模拟接口调用 var that = this; setTimeout(function () { //模拟接口调用 if (uname == 'admin') { that.tip = '用户名已经存在,请更换一个'; } else { that.tip = '用户名可以使用' } }, 1000) } }, watch: { uname: function (val) { //调用后台接口验证用户名的合法性 this.checkName(val); //修改提示信息 this.tip = '正在验证中...' } } }); </script> </body> </html> 5.6 过滤器1.过滤器的作用是什么?
2.全局过滤器 Vue.filter('过滤器名称',function(value){ //过滤器业务逻辑 }) 3.过滤器的使用 <div>{{msg |upper}}</div>//upper为过滤器名称 <div>{{msg |upper | lower}}</div>//级联操作 <div :id='id | formatId'></div> 4.局部过滤器 filters:{ upper:function(val){ return val.charAt(0).toUpperCase() + val.slice(1); } } //10-过滤器基本用法.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <input type="text" v-model='msg'> <div>{{msg | upper}}</div> <div>{{msg | upper | lower}}</div> <div :abc='msg | upper'>测试数据</div> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> Vue.filter('lower', function (val) { return val.charAt(0).toLowerCase() + val.slice(1); }); var vm = new Vue({ el: '#app', data: { msg: '' }, filters: { upper: function (val) { //拿到首字母将其变成大写,然后和后面的字母拼接 return val.charAt(0).toUpperCase() + val.slice(1); } } }); </script> </body> </html> 5.带参数的过滤器 Vue.filter('format',function(value,arg){ //从arg开始接收参数 }) 6.过滤器的使用 <div>{{data | format('yyyy-MM-dd')}}</div> 案例:使用过滤器格式化时期 //10-过滤器基本用法.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="app"> <div>{{date | format('yyyy-MM-dd hh:mm:ss')}}</div> </div> <script type="text/javascript" src="js/vue.js"></script> <script type="text/javascript"> Vue.filter('format', function(value, arg) { function dateFormat(date, format) { if (typeof date === "string") { var mts = date.match(/(\/Date\((\d+)\)\/)/); if (mts && mts.length >= 3) { date = parseInt(mts[2]); } } date = new Date(date); if (!date || date.toUTCString() == "Invalid Date") { return ""; } var map = { "M": date.getMonth() + 1, //月份 "d": date.getDate(), //日 "h": date.getHours(), //小时 "m": date.getMinutes(), //分 "s": date.getSeconds(), //秒 "q": Math.floor((date.getMonth() + 3) / 3), //季度 "S": date.getMilliseconds() //毫秒 }; format = format.replace(/([yMdhmsqS])+/g, function(all, t) { var v = map[t]; if (v !== undefined) { if (all.length > 1) { v = '0' + v; v = v.substr(v.length - 2); } return v; } else if (t === 'y') { return (date.getFullYear() + '').substr(4 - all.length); } return all; }); return format; } return dateFormat(value, arg); }) var vm = new Vue({ el: '#app', data: { date: new Date() } }); </script> </body> </html> 5.7 Vue生命周期
1.主要阶段 挂载(初始化相关属性) beforeCreatecreatedbeforeMountmounted 更新(元素或组件的变更操作) beforeUpdateupdated 销毁(销毁相关属性) beforeDestroydestroyed 2.Vue实例的产生过程
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-biZCGRVM-1620742265770)(Vue全家桶之Vue基础.assets/5.15.png)] 6.综合案例:图书管理案例:图书管理 案例:补充知识1.数组相关API:变异方法(修改数组)
2.数组相关API:替换数组(生成新的数组)
3.数组响应式变化:修改响应数据
参数一表示要处理的数组名称 1.图书列表
2.添加图书
3.修改图书
4.删除图书 删除按钮绑定事件处理方法 实现删除业务逻辑 5.常用特性应用场景 过滤器(格式化日期)自定义指令(获取表单焦点)计算属性(统计图书总数)侦听器(验证图书存在性)生命周期(图书数据处理) <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <!-- css样式 --> <style type="text/css |
请发表评论