• 【vue2.0】


    vue简介

    1.vue是什么?
    vue是一套用于构建用户界面的渐进式javascript框架

    渐进式:vue可以自底向上逐层的引用。
    简单应用:只需一个轻量小巧的核心库。
    复杂应用:可以引入各式各样的vue插件

    2.vue的特点

    • 采用组件化模式,提高代码复用率,且让代码更好维护。
      在这里插入图片描述

    • 声明式编码,让编码人员无需直接操作DOM,提高开发效率。
      在这里插入图片描述

    • 使用虚拟DOM(内存里的数据)+优秀的Diff算法,尽量复用DOM节点。
      在这里插入图片描述

    搭建开发环境

    在这里插入图片描述

    root可以更换为js获取dom的写法

    1.cdn
    2.npm
    在这里插入图片描述

    vue实例和容器只能一一对应,不可一对多也不可多对一

    注意区分:js表达式和js代码(语句)

    1. 表达式:一个表达式会产生一个值,可以放在任何一个需要值的地方:
      a
      a+b
      demo(1)
      x==y?‘a’:‘b’
    2. js代码(语句)
      if(){}
      for(){}

    模板语法

    1. 差值语法
      *功能:*用于解析标签体内容
      写法:{{xxx}},xxx是js表达式,且可以直接读取到data中的所有属性。
    2. 指令语法:
      功能: 用于解析标签(包括:标签属性、标签体内容、绑定事件…)
      距离: (v-bind是单向数据绑定{能根据数据展示,但不能跟页面改变而改变数据})v-bind:href=“xxx”或者简写为:href=“xxx”,xxx同样要写js表达式,且可以直接读取到data中的所有属性。
      备注: vue中有很多指令,且形式都是v-??,此处只是拿v-bind举个栗子

    数据绑定

    单向数据绑定:v-bind{数据只能从data流向页面}
    双向数据绑定:v-model{数据不仅能从data流向页面,还可以从页面流向data}

    v-model只能绑定表单元素(input…)表单元素都有value
    v-model:value可以简写成v-model,因为v-model默认收集的是value值

    el与data的两种写法

    在这里插入图片描述
    在这里插入图片描述

    在对象里面写函数可以省略:function,这里需要特别注意不可以写箭头函数,一旦写了箭头函数,this就不在是vue实例了

    理解mvvm

    在这里插入图片描述

    数据代理

    数据代理:通过一个对象代理对另一个对象中属性的操作(读/写)

    let number = 18
    let person = {
    	name:'zhangsan',
    	sex:'boy',
    }
    Object.defineProperty(person,'age',{
    	//value:18,
    	//enumerable:true,//控制属性是否可以被枚举,默认值是false
    	//writeable:true,//控制属性是否可以被修改,默认值是false
    	//configurable:true,//控制属性是否可以被删除,默认值是false
    	//当有人读取person的age属性时,get函数(getter)就会被调用,且返回值就是age值
    	get:function(){
    		console.log('有人读取age属性了')
    		return number
    	},
    	//当有人修改person的age属性时,set函数(setter)就会被调用,且收到返回修改的值
    	set:function(value){
    		console.log('有人修改时')
    		number = value
    	}
    })
    

    在这里插入图片描述

    1. vue中的数据代理:
      通过vm对象来代理datra对象中属性的操作(读/写)
    2. vue中数据代理的好处:
      更加方便的操作data中的数据
    3. 基本原理:
      通过Object.defineProperty()把data对象中所有属性添加到vm上
      为每一个添加到vm上的属性,都指定一个getter/setter
      在getter/setter内部去操作(读/写)data中对应的属性

    事件

    事件传参

    事件1
    事件2
    //传参就加口号,不传参就不加 methods:{ info(event){ console.log(event) }, info(event,number){ console.log(event,number) } }
    1. 使用v-on:xxx或@xxx绑定事件,其中xxx是事件名
    2. 事件的回调需要配置在methods对象中,最终会在vm上
    3. methods中配置的函数,不要用箭头函数!否则this就不是vm了
    4. methods中配置的函数,都是被vue所管理的函数,this的指向是vm或组件实例对象
    5. @click=“demo”和@click=“demo($event)”效果一致,但后者可以传参

    事件修饰符

    1. .prevent:阻止默认事件
    2. .stop:阻止事件冒泡
    3. .once:事件只触发一次
    4. .capture:使用事件捕获模式
    5. .self:只有event.target是当前操作的元素是才触发事件
    6. .passive:事件的默认行为立即执行,无需等待事件回调执行完毕
    7. number 配合input表单type属性为number一起使用,将其数据变成数字类型
    8. lazy:配合textarea一起使用当这个失去焦点的时候将其数据响应(不加会边输入边存储)
    9. trim 去掉前后空格

    键盘事件

    1. enter 回车
    2. delete 删除和退格
    3. esc 退出
    4. space 空格
    5. tab换行(特殊:必须要配合keydown去使用)
    6. up上
    7. down
    8. left
    9. right
    <button @keyup.enter="getInfo">点击获取信息button>
    

    系统修饰键:
    ctrl、alt、shift、meta(win键)
    配合keyup使用:按下修饰键的同时,在按下其他键,事件才会被处罚
    配合keydown使用,正常触发
    修饰符可以连续写

    计算属性

    计算属性与methods的优势:计算属性内部有缓存机制(复用),效率更高,调试方便。

    	<div>{{fullName}}div>
    

    完整写法

    computed:{
    	fullName:{
    		//get的作用:当有人读取fullName的时候
    		//get什么时候调用:1.初次读取fullName。2.所依赖的值发生变化的时候****
    		get(){
    			return this.firstName+ '-' + this.lastName
    		},
    		//set什么时候调用:当fullName被修改的时候
    		set(value){
    			const arr = value.split('-')
    			this.firstName = arr[0]
    			this.lastName = arr[1]
    		}
    	}
    }
    
    

    简写写法:只读不改才可以简写

    computed:{
    	fullName(){
    		return this.firstName+ '-' + this.lastName
    	}
    }
    

    监视属性

    1. 当被监视的属性变化时,回调函数自动调用,进行相关操作
    2. 监视的属性必须存在,才能进行监视
    3. 监视的两种写法
      1. new Vue传入watch配置
      2. 通过vm.$watch监视
    watch:{
    	isHot:{
    		immediate:true,//初始化时让handle调用一下
    		//handler什么时候调用?当isHot发生改变时
    		handler(newValue,oldValue){
    			console.log(newValue,oldValue)
    		}
    	}
    }
    

    深度监视

    data:{
    	numbers:{
    		a:1,
    		b:2
    	}
    },
    watch:{
    //监视多级结构中某个属性的变化
    	'numbers.a':{
    		handler(){
    			console.log('a被改变了')
    		}
    	},
    	//监视多级结构中所有属性的变化
    	numbers:{
    		deep:true,//深度监视
    		handler(){
    			console.log('numbers被改变了')
    		}
    	}
    }
    

    简写写法:前提不需要deep和innediate的时候使用

    //1.
    watch:{
    	//监视多级结构中所有属性的变化
    	isHot(newValue,oldValue){
    		console.log('isHot被改变了')
    	}
    }
    //2.
    const vm = new Vue({})
    vm.$watch('isHot',function(newValue,oldValue){console.log('isHot被改变了')})//不允许写箭头函数--会改变this指向
    

    深度监视:

    1. vue中的watch默认不监视对象内部值的改变(一层)
    2. 配置deep:true可以检测对象内部值改变(多层)
      备注:
    3. vue自身可以检测对象内部值的改变。但vue提供的watch默认不可以
    4. 使用watch时根据数据的具体结构,决定是否才用深度监视

    watch和computed的区别:

    1. computed能完成的功能,watch都可以完成
    2. watch能完成的功能,computed不一定能完成。eg:watch可以进行异步操作
      两个重要的小原则
    3. 所被vue管理的函数,最好写成普通函数,这样this的指向才是vm或组件实例对象。
    4. 所有不被vue所管理的函数(定时器的回调函数、ajax的回调函数等),最好写成箭头函数,这样this的指向才是vm或组件实例对象。

    列表过滤
    在这里插入图片描述
    在这里插入图片描述
    所以两者选择计算属性更好
    +排序
    在这里插入图片描述

    当每次用什么方法你需要想到:这个方法能收到什么+需不需要写返回值+改变不改变原数组

    class绑定样式

    1. 绑定class样式-----字符串写法,适用于:样式的类名不确定,需要动态绑定
    <div class="basic" :class="mood" @click="changeMood">{{name}}div>
    
    data:{
    	mood:'normal'
    },
    methods:{
    	changeMood(){
    		this.mood='haapy'
    	}
    }
    
    1. 绑定class样式-----数组写法:适用于:要绑定的样式个数不确定、名字也不确定
    <div class="basic" :class="classArr">{{name}}div>
    
    data:{
    	classArr:['normal','normal1']
    },
    
    1. 绑定class样式----对象写法,适用于:要绑定的样式个数确定、名字也确定,但要动态决定用不用
    <div class="basic" :class="classObj">{{name}}div>
    
    data:{
    	classObj:{
    		normal:true,
    		normal2:false,
    	}
    },
    

    绑定style样式

    1. 对象
    2. 数组
    <div :style="styleObj">{{name}}div>
    <div :style="styleArr">{{name}}div>
    
    data:{
    	styleObj:{
    		fontSize:'40px'
    	},
    	styleArr:[
    		{backgroundColor:'red'}
    	]
    },
    

    条件渲染

    1. v-if
    写法:
    v-if=“表达式”
    v-else-if=“表达式”
    v-else=“表达式”
    适用于:切换频率较低的场景
    特点:不展示的DOM元素直接被移除
    注意:v-if可以喝v-else-if、v-else一起使用,但要求结构不能被打断
    
    1. v-show
    写法:
    v-show=“表达式”
    适用于:切换频率较高的场景
    特点:不展示的DOM元素未被移除,仅仅是使用样式隐藏掉
    

    备注:使用v-if的时,元素可能无法获取到,而使用v-show一定可以获取到

    列表渲染

    v-for指令

    1. 用于展示列表数据
    2. 语法:v-for=“(item,index) in xxx” :key=“yyy”
    3. 可遍历:数组、对象、字符串(用的很少)、指定次数(用的很少)

    key的作用
    在这里插入图片描述
    在这里插入图片描述

    1. 虚拟DOM中key的作用:
      key是虚拟DOM对象的标识,当状态中的数据发生变化时,vue会根据【新数据】生成【新的虚拟DOM】,随后vue进行【新虚拟DOM】与【旧虚拟DOM】的差异比较
    2. 对比规则:
      1. 旧虚拟DOM中找到了与新虚拟DOM相同的key:
        若虚拟DOM中内容没变,直接使用之前的真实DOM
        若虚拟DOM中内容变了,则生成新的真实DOM,随后替换掉页面中之前的真实DOM
      2. 旧虚拟DOM中未找到与新虚拟DOM相同的key
        创建新的真实DOM,随后渲染到页面
    3. 用index作为key可能会引发的问题:
      1. 若对数据进行:逆序添加、逆序删除等破坏顺序操作:会产生没有必要的真实DOM更新==》界面效果没问题,但效率低
      2. 如果结构中还包含输入类的DOM,会产生错误DOM更新==》界面有问题
    4. 开发中如何选择key
      1. 最好使用每条数据的唯一标识作为key,比如id、手机号、身份证号、学号等唯一值
      2. 如果不存在对数据的逆序添加、逆序删除等破坏顺序操作,仅用于渲染列表用于展示,使用index作为key是没有问题的

    vue监视数据

    1. vue会监视data中所有层次的数据
    2. 如何检测对象中的数据?
      通过setter实现检测,且要在new vue时就传入要检测的数据
      1. 对象中后追加的属性,vue默认不做响应式处理
      2. 如需给后添加的属性做响应式,请使用如下
        Vue.set(target,propertyName/index,value)或
        this/vm.$set(target,propertyName/index,value)
    3. 如何检测数组中的数据?
      通过包裹数组更新元素的方法实现,本质就是做了两件事
      1. 调用原生对应的方法对数组进行更新
      2. 重新解析模板,进而更新页面
    4. 在vue修改数组中的某个元素一定要用如下方法
      1. 使用这些API:push() pop() shift() unshift() splice() sort() reverse()
      2. Vue.set()或vm.$set()

    特别注意:Vue.set()和vm.$set()不能给vm或vm的根数据对象添加属性

    过滤器

    日期过滤:bootcdn------mont.js/day.js
    在这里插入图片描述
    在这里插入图片描述

    定义:对要显示的数据进行特定格式化再显示(适用于一些简单逻辑的处理)
    语法:

    1. 注册过滤器:Vue.filter(name,callback)或new Vue(filters:{})
    2. 使用过滤器:{{xxx|过滤器名}}或v-bind:属性=‘xxx|过滤器名’
      备注:
    3. 过滤器也可以接收额外参数、多个过滤器也可以串联
    4. 并没有改变原来的数据,是产生新的对应的数据

    指令

    1. v-on/@ 事件
    2. v-bind 单向绑定
    3. v-model 双向绑定
    4. v-for 遍历数组、对象、字符串
    5. v-if条件渲染
    6. v-else-if条件渲染
    7. v-else条件渲染
    8. v-show条件渲染
    9. v-text渲染文本内容

    v-text与{{}}(差值)语法的区别:v-text会替换节点中的内容,而差值不会

    1. v-html 渲染包含html结构的内容

    与差值语法的区别:

    1. v-html会替换掉节点中所有的内容,差值不会
    2. v-html可以识别html结构
      注意:html有安全性问题
    3. 在网络上动态渲染任意html是非常尾项的,容易导致xss攻击。
    4. 一定要在可信的内容上使用v-html,永不要用在用户提交的内容上
    1. v-clock
    
    

    本质是一个特殊属性,vue实例创建完毕并接管容器后,会删掉v-clock属性
    使用css配合v-clock可以解决网速慢时页面展示出{{xxx}}的问题

    1. v-once:所有节点在初次动态渲染后,就视为静态内容了。以后数据的改变不会引起v-once所在结构的更新,可以用于优化性能
    <div v-once>初始化值{{n}}div>//点击之后还是初始化
    <div >当前的值{{n}}div>//点击之后会根据点击的逻辑变化
    <button @click="n++">+1button>
    
    1. v-pre:跳过其所在节点的编译过程。可利用他掉过:没有使用指令语法、没有使用差治愈大的节点,会加快编译
    //效果
    <div v-once>{{n}}div>//页面展示:{{n}}
    //一般放在不需要解析的dom节点是上-这样就不需要解析了
    <div v-once>hahhahahdiv>//页面展示:hahhahah
    

    自定义指令

    自定义指令何时调用:

    1. 指令与元素成功绑定时(一上来)
    2. 指令所在的模板被重新解析时

    函数式

    <div v-big="n">div>
    //如果自定义指令的名字是多个-用-分割
    <div v-big-number="n">div>
    
    directives:{
    	big(element,binding){
    		element.innerText = binding.value
    		console.log(element,'被绑定的元素',binding,'绑定给的值')
    	},
    	'big-number'(element,binding){
    		element.innerText = binding.value
    		console.log(element,'被绑定的元素',binding,'绑定给的值')
    	}
    }
    

    对象式

    <input type="text" v-fbing=""/>
    
    //对象写法是只有bind+update
    //局部指令
    directives:{
    	fbing:{
    	//指令与元素成功绑定时(一上来)
    		bind(element,binding){
    			element.innerText = binding.value
    		},
    		//指令所在元素被插入页面时
    		inserted(element,binding){
    			element.focus()
    		},
    		//指令所在的模板被重新解析时
    		update(element,binding){
    			element.innerText = binding.value
    		}
    	}
    }
    //全局指令
    //对象
    Vue.directive('fbing',{
    	bind(element,binding){
    	element.innerText = binding.value
    	},
    	//指令所在元素被插入页面时
    	inserted(element,binding){
    		element.focus()
    	},
    	//指令所在的模板被重新解析时
    	update(element,binding){
    		element.innerText = binding.value
    	}
    })
    //函数
    Vue.directive('big',function(element,binding){
    	element.innerText = binding.value
    	console.log(element,'被绑定的元素',binding,'绑定给的值')
    })
    

    所有指令相关的函数this指向是window—写箭头函数和正常函数都可

    生命周期

    在这里插入图片描述

    常用的生命周期钩子:

    1. mounted:发送ajax请求、启动定时器、绑定自定义事件、订阅消息等【初始化操作】
    2. beforeDestroy:清除定时器、解绑自定义事件、取消订阅消息【收尾工作】
      关于销毁vue实例:
    3. 销毁后借助vue开发者工具看不到任何信息
    4. 销毁后自定义事件会失效,但原生dom事件依然有效
    5. 一般不会在beforeDestroy操作数据,因为即便操作数据,也不会再触发更新流程了

    组件

    **定义:**实现应用中局部功能代码和资源的集合
    使用组件的三大步骤:

    1. 定义组件(创建组件)
    2. 注册组件
    3. 使用组件(写组件标签)
      如何定义一个组件?
      使用vue.extend(options)创建,其中options和new Vue(options)时传入的那个options几乎一样,但也有点区别:
      区别如下:
    4. el不要写,为什么?——最终所有的组件都要经过一个vm的管理,由vm中的el的决定服务哪个容器
    5. data必须写成函数,为什么?——避免组件被复用时,数据存在引用关系

    备注:使用templete可以配置组件结构

    如何注册组件?

    1. 局部注册:new Vue({components:{}})
    2. 全局注册:Vue.component(‘组件名’,组件)
      编写组件标签
      <组件名>

    注意事项:

    1. 组件名写法:
      一个单词组成:首字母小写+手字母大写
      多个单词组成:my-school和MySchool
      备注:
      1.组件名尽可能会比html中已有的元素名称,例如:h2和H2都不行
      2. 可以使用name配置项指定组件在开发者工具中呈现的名字
    2. 关于组件的标签:
      第一种写法: <组件名>
      第二种写法: <组件名/>
      备注:不用使用脚手架时,<组件名/>会导致后续组件不能渲染
      一个简写方式:
      const school = vue.extend(options)可简写const school = options

    非单文件组件

    定义:一个文件中包含有n个组件

    单文件组件

    定义:一个文件中只包含1个组件

    vueComponent构造函数

    1. school组件本质是一个名为vueComponent构造函数,且不是程序员定义的,是vue.extend生成的
    2. 我们只需要写或,vue解析时会帮我们创建school组件的实例对象,即vue帮我们执行的:new vueComponent(options)
    3. 特别注意:每次调用vue.extend,返回的都是一个个全新的vueComponent
    4. 关于this指向
      1. 组件配置中:data函数、methods函数、watch函数、computed中的函数 他们的this均是【vueComponent实例对象】
      2. new vue(options)配置中:data函数、methods函数、watch函数、computed中的函数 她们的this均是【vue实例对象】
    5. vueComponent的实例对象,以后简称vc(也可称之为:组件实例对象)
      vue实例对象以后简称vm
  • 相关阅读:
    【PID优化】基于头脑风暴算法PID控制器优化设计含Matlab源码
    数据分析总结
    玄子Share- IDEA 2023 Web 热部署
    uniapp uview 头像裁剪组件的问题
    【Android笔记21】Android中的导航栏ActionBar的介绍及使用
    TAMRA phosphoramidite, 5-isomer,TAMRA磷酰胺,5-异构体
    DCOM升级OPCDA客户端(Java-utgrad)失效处理
    使用3DMax制作一个象棋棋子
    代码随想录贪心算法——买卖股票的最佳时机含手续费
    buuctf-web-p6 [NPUCTF2020]web 狗
  • 原文地址:https://blog.csdn.net/weixin_47416539/article/details/126949644