IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 尚硅谷《vue》——笔记一 -> 正文阅读

[JavaScript知识库]尚硅谷《vue》——笔记一

前言

前后端分离人不分离,这就是为什么我在学前端。


一、数据绑定

1. 模板语法

<h1>插值语法{{name}}</h1>
<a :href="url">指令语法</a>

2. 数据绑定

<input type="text" v-bind:value="name">单向数据绑定</input>
<input type="text" v-model:value="name">双向数据绑定(只能应用在表单类元素上)</input>

3. el与data的两种写法

// 第一种写法(el和data的写法是分离的,可以排列组合得到四种不同写法)
new Vue({
	el:'#root',
	data:{
		name:'尚硅谷',
	}
})
// 第二种写法
const vm = new Vue({
	data:{
		return {
			name:'尚硅谷',
		}
	}
})
vm.$mount('#root')

二、MVVM

在这里插入图片描述
解释:
M:模型->data数据
V:视图->模板,DOM
VM:视图模型->Vue实例对象
双向绑定:

  1. 数据通过Vue绑定到DOM
  2. DOM通过DOM监听数据

三、数据代理

利用defineProperty给对象添加属性,并将属性的值与其他数据绑定。

let number = 18
Object.defineProperty(person,'age',{
	value:18,
	enumerable:true, // 可枚举forin
	writable:true, // 可修改
	configurable:true, // 可删除
	get:function(){
		return number;
	},
	set:function(value){
		number=value;
	}
})

vm.name是通过defineProperty代理data.name得到的:

/** vm._data===data */
let data = {
	name:'尚硅谷',
}
const vm = new Vue({
	el:'#root',
	data:data,
})

四、事件处理

1. 绑定事件

<button v-on:click="clickButton"></button>
<button @click="clickButton(123, $event)"></button>

2. 事件修饰符(前四个常用)

<myButton @click.native="clickButton">自定义组件myButton使用native修饰符接收原生事件</myButton>
<button @click.prevent="clickButton">阻止默认事件</button>
<button @click.stop="clickButton">阻止事件冒泡</button>
<button @click.once="clickButton">事件只触发一次</button>
<button @click.capture="clickButton">使用事件捕获模式</button>
<button @click.self="clickButton">只有event.target是当前操作的元素时才触发</button>
<button @click.passive="clickButton">事件的默认行为立即执行,无需等待事件的回调执行完成</button>

3. 滚动和键盘事件

// 滚动事件
<ul @scroll="scroll">滚动条事件</ul>
<ul @wheel="wheel">鼠标滚动</ul>
// 键盘事件
<input @keyup.enter="search">释放回车键触发函数</input>
// 特殊按键:tab、ctrl、alt、shift、meta(windows徽标键)
<input @keyup.ctrl="search">按键同时按下其他键,然后释放其他键,事件触发</input>
<input @keydown.ctrl="search">正常触发事件</input>
<input @keydown.tab="search">tab必须配合keydown使用,因为它会让当前元素失去焦点</input>
<input @keyup.ctrl.y="search">同时按下ctrl和y</input>

五、计算属性

底层借助Object.defineProperty方法提供的getter和setter

new Vue({
	computed:{
		fullName:{
			// get调用时机:1.初次被读取;2.所依赖的数据发生变化;否则直接走缓存
			get(){
				return firstName + '-' + lastName;
			}
			set(value){
				const arr = value.split('-')
				this.firstName = arr[0]
				this.lastName = arr[1]
			}
		},
		// 只读时的简写
		fullName(){
			return firstName + '-' + lastName;
		}
	}
})

六、监视属性

watch属性

new Vue{
	watch:{
		isHot:{
			immediate:true, // 初始化时调用
			deep:true, // 开启深度监视
			handler(newValue, oldValue){
				console.log('值修改了')
			}
		},
		// 简写
		isHot(newValue, oldValue){
			console.log('值修改了')
		}
	}
}

watch与computed对比

computed无法开启异步任务而watch可以

是否使用箭头函数

  1. 所有被Vue管理的函数,最好写成普通函数,这样this才指向vm或组件实例;
  2. 所有不被Vue管理的函数(定时器会标、ajax回调、promise回调),最好写成箭头函数,这样this才指向vm或组件实例。

七、绑定样式

<!-- class -->
<div :class="mood">字符串写法,样式类名不确定,需动态指定</div>
<div :class="classArr">数组写法,要绑定的样式个数不确定,样式类名也不确定</div>
<div :class="classObject">对象写法,个数确定,样式类名也确定,但要动态决定用不用</div>
<!-- style -->
<div :style="styleObject">对象写法,key不能乱写</div>
new Vue({
	data:{
		mood:"normal", // normal是样式名
		classArr:['atguigu1','atguigu2'],
		classObject:{
			atguigu1:true,
			atguigu2:false,
		},
		styleObject:{
			fontSize: '40px',
			color:'red',
		}
	}
})

八、条件渲染

<div v-show='false'>隐藏,但是元素还在</div>
<div v-if='n===1'>隐藏,但是元素不在了</div>
<div v-else-if='n===2'>else-if</div>
<div v-else>else</div>
<!-- v-if与template配合使用,不能用v-show。template不会破坏原有结构 -->
<template v-if='n === 1'>
	<div/>
	<div/>
</template>

九、列表

1. 渲染

key的作用: 列表中的key是虚拟DOM对象的标识,数据发生变化时,Vue根据新数据生成新的虚拟DOM,然后根据key对比新旧虚拟DOM,判断是否需要更新真实DOM。
index作为key可能出现的问题: 在数组的非末尾增删数据,会导致没有必要的真实DOM更新。如果结构中包含输入类的DOM,界面显示会有问题。

<!-- 遍历数组 -->
<li v-for='(item, index) in persons' :key='item.key'>{{ item.name }}</li>
<!-- 遍历对象 -->
<li v-for='(value, key) of persons' :key='key'>{{ key }}:{{ value }}</li>

2. 过滤、排序

computed:{
	filPersons(){
		const arr = this.persons.filter((p)=>{
			return p.name.indexOf(this.keyWord) !== -1;
		})
		if(this.sortType){
			arr.sort((p1, p2)=>{
				return p1.age-p2.age;
			})
		}
		return arr;
	}
}

十、Vue监视数据

1. 监视原理–对象

let data = {
	name:'尚硅谷',
}
function Observer(obj){
	// 汇总对象中所有的属性,遍历,配置setter和getter
	const keys = Object.keys(obj)
	keys.forEach((k)=>{
		Object.defineProperty(this, k, {
			get(){
				return obj[k];
			},
			set(val){
				obj[k] = val;
			}
		})
	})
}
// 创建一个监视的实例对象,用于监视data中属性的变化
const obs = new Observer(data)
// 准备一个vm对象
let vm = {}
vm._data = data = obs

vue还做了两件事:

  1. 使用vm.name代理vm._data.name;
  2. 递归配置setter和getter

2. 在对象中追加属性——$set方法

向响应式数据添加属性,并确保新的属性也是响应式的
注意:只能给data里的对象添加属性,不能给Vue实例或Vue实例的根数据对象(_data)添加

this.$set(this.student, 'sex', '女')

3. 监视数组

Vue没有给数组的下标配置监测,所以Vue监视不到通过下标修改数组数据。

对数组的修改要通过push、pop、shift、unshift、splice、sort、reverse进行,Vue才能监视到数据的变化(Vue对这些函数进行了包装)。

十一、指令

1. 内置指令

  1. v-text
    向节点渲染文本内容,会替换掉节点内容
<div v-text="name">你好,</div>
  1. v-html
    可以将数据解析为html节点,会替换掉节点内容
    严重注意:在网页上动态渲染HTML是非常危险的,容易导致XSS攻击
<div v-html="htmlStr">你好,</div>
  1. v-cloak
    与css配合,防止网速过慢的时候未经解析的模板显示在界面上。
<!-- 一旦Vue接管容器,会删掉v-cloak属性 -->
<div v-cloak>{{ name }}</div>
[v-cloak]{
	display:none;
}
  1. v-once
    节点中的内容在初次动态渲染后就视为静态内容,数据变化结构不会再更新
<div v-once>{{ n }}</div>
  1. v-pre
    跳过所在节点的编译过程,加快编译
<div v-pre>Vue</div>

2. 自定义指令

big-num函数被调用的时机:(1)指令与元素成功绑定时;(2)指令所在的模板被重新解析时
注意:指令内函数的this是windows

<h2>当前的n值是:<span v-text="n"></span></h2>
<h2>放大10倍后的n值是:<span v-big-num="n"></span></h2>
<!-- v-fbind功能与v-bind类似,但在展示时能自动获取焦点 -->
<input type='text' v-fbind:value='n'/>
directives:{
	// 函数式
	'big-num'(element, binding){
		element.innerText = binging.value*10
	},
	// 对象式
	fbind:{
		// 指令与元素成功绑定时
		bind(element, binding){
			element.value = binding.value;
		},
		// 指令所在元素被插入页面时
		inserted(element, binding){
			element.focus();
		},
		// 指令所在模板被重新解析时
		update(){
			element.value = binding.value;
		},
	}
}

总结

倦了,下次继续(咕咕咕)

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-10-31 11:46:33  更:2022-10-31 11:49:08 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 17:59:10-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码