vue的笔记(1)

简介: vue的笔记

一,Vue核心

1.1 vue简介

  1. 采用组件化,提高代码复用率
  2. 声名式编码,无需操作DOM提高开发效率
  3. 使用虚拟DOM+优秀的Diff算法,尽量复用DOM节点。

原本是新增的东西一股脑的覆盖,现在是有个虚拟的DOM原本有的就给保留,然后插入新的东西

初识Vue:

1.想让Vue工作,就必须创建一个Vue实例,且要传入一个配置对象;

2.root容器里的代码依然符合html规范,只不过混入了一些特殊的Vue语法;

3.root容器里的代码被称为【Vue模板】;

1.2初识vue

1.想让Vue工作,就必须创建一个Vue实例,且要传入一个配置对象;

2.root容器里的代码依然符合html规范,只不过混入了一些特殊的Vue语法;

3.root容器里的代码被称为【Vue模板】;

4.Vue实例和容器是一一对应的;

5,真实开发中只有一个Vue实例并且会配合着组件一起使用;

6.{{xxx}}中的xxx要写js表达式,且xxx可以自动读取到data中的所有属性;(如果data里面的数据是字符串就可以在大括号里面使用字符串的属性)

7.一旦data中的数据发生改变,那么模板中用到该数据的地方也会自动更新;

[!danger]

一个容器只能对应一个Vue实例

{{}}里面包裹的必须是js表达式

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

1.表达式:一个表达式会生成一个值,可以放在任何一个需要值的地方:

(1). a

(2). a+b

(3). demo(1)

(4).x === y ? ‘a’ : ‘b’

目的:因为数据是动态的,为了一旦把动态数据交给vue实例,以后vue中的数据发生变化,整个页面的这个地方也一起发生变化

这个root代表的是根,是Vue实例

1.3vue模板语法

1.3.1 插值语法&指令语法

hello,{{name}}

<script type="text/javascript">
        new Vue({
            el: '#root', //el用于指定当前Vue实例为那个容器服务,值通常为css选择器字符串
            data: { //data用于存储数据,数据供el所指定的容器使用
                name: '哈哈哈'
            }
        })
    </script>
    ```
     
`    <a href={{ url}}>11111</a>`
这种不能插入url
```vue
<div id="root">
    <!-- 插值语法 -->
    <h1>hello,{{name}}</h1>
    <a v-bind:href="url">11111</a>
</div>

绑定:把表达式执行的结果绑定给href

这里就是把绿色框里面的url当初表达式来执行而不是字符串

v-bind: 可以简写成:

总结

插值语法往往用在标签体里面,指令语法往往用在标签属性,事件等

1.4 vue数据绑定

v-bind 只是单向的数据绑定

v-model双向绑定

[!danger]

v-model只能应用在表单类元素上面

总结:

Vue中有2种数据绑定的方式:

1.单向绑定(v-bind):数据只能从data流向页面。

2.双向绑定(v-model):数据不仅能从data流向页面,还可以从页面流向data。

备注:

1.双向绑定一般都应用在表单类元素上(如: input、select等)

2.v-model:value 可以简写为v-model,因为v-model默认收集的就是value值.。

el和data的两种写法

l/el的两种写法

const v = new Vue({
el: " #root',    //第一种写法
data:{
name:"尚硅谷'
})
console.log(v)
v.$mount('#root')//第二种写法*/

灵活使用容器

data

//data的第二种写法:函数式
data:function(){
return{
name:"尚硅谷
}
}

这种function函数是由vue对象来调,但是箭头函数不行

另外可以简写成

data(){
return{
name:"尚硅谷
}
}

1.5MVVM模型

1.M:模型(Model) :对应data中的数据

2.V:视图(View):模板

3.VM:视图模型(ViewModel) : Vue实例对象

[!理解]

view是html中我们设置的模板,model是数据,vm是实现模型和数据绑定的对象

观察发现:

1.data中所有的属性,最后都出现在vm身上。

2.vm身上所有的属性及Vue原型上所有属性,在Vue模板中都可以直接使用。

1.6 数据代理

defineProperty 让number与age产生了关联

我们可以把vue看成别人封装好的工具类,传入的参数是自身的自定义类,该自定义类继承了vue接口,可定义vue接口的属性值,也可以自行定义成员变量,成员属性,成员方法等,这些都可以被vue实例接管

1.7 事件处理

<div id="root">
<h2>欢迎来到{{name}}学习</h2>
<!-- <button v-on:click="showInfo">点我提示信息</button> --><button @click="showInfo1">点我提示信息1</button>
<button @click="showInfo2($event,66)">点我提示信息2</button></div>
</body>
<script type="text/javascript">
Vue.config.productionTip = false l/阻止 vue在启动时生成生产提示。
const vm = new Vue({
el: " #root',
data:{
name:'尚硅谷'}
methods:{
showInfo1(event){ …
showInfo2(event, number)iconsole.log(event,number)
// console.log(event.target.innerText)l / console.log(this)//此处的this是vmll
         alert( '同学你好!!')I
F
}})
/script>

1.7.2事件修饰符

1.prevent: P阻止队手件(滑用);

2.stop:阻止事件冒泡(常用);

3.once:事件只触发一次(常用);

4.capture:使用事件的捕获模式;

5.self:只有event.target是当前操作的元素时才触发事件;

6.passive:事件的默认行为立即执行,无需等待事件回调执行完毕;

使用捕获模式,先捕获再冒泡

self:只有event.target是当前操作的元素时才触发事件;

1.7.3. 按键修饰符

  1. keycode : 操作的是某个 keycode 值的键
  2. .keyName : 操作的某个按键名的键(少部分)
    1.Vue中常用的按键别名:
    回车 => enter
    删除=>delete(捕获“删除”和“退格”键)退出=>esc
    空格=>space
    换行=> tab(特殊,必须配合keydown去使那
    上=> up
    下=> down
    左=>left
    右=> right

2.Vue未提供别名的按键,可以使用按键原始的key值去绑定,但注意要转为kebab-case(短横线命名)

3.系统修饰键(用法特殊): ctr1、alt、shift、meta

(1).配合keyup使用:按下修饰健的同时,再按下其他键,随后释放其他键,事件才被触发。

(2).配合keydown使用:正常触发事件。

4.也可以使用keyCode去指定具体的按键(不推荐)

5.Vue.config.keyCodes.自定义键名=键码,可以去定制按键别名

返回值插值进大括号

vue的笔记(2)https://developer.aliyun.com/article/1530393

相关文章
|
28天前
|
人工智能 JavaScript 算法
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
192 0
|
29天前
|
JavaScript UED
用组件懒加载优化Vue应用性能
用组件懒加载优化Vue应用性能
|
1月前
|
JavaScript 前端开发 开发者
Vue 自定义进度条组件封装及使用方法详解
这是一篇关于自定义进度条组件的使用指南和开发文档。文章详细介绍了如何在Vue项目中引入、注册并使用该组件,包括基础与高级示例。组件支持分段配置(如颜色、文本)、动画效果及超出进度提示等功能。同时提供了完整的代码实现,支持全局注册,并提出了优化建议,如主题支持、响应式设计等,帮助开发者更灵活地集成和定制进度条组件。资源链接已提供,适合前端开发者参考学习。
160 17
|
1月前
|
监控 JavaScript 前端开发
Vue 文件批量下载组件封装完整使用方法及优化方案解析
本文详细介绍了批量下载功能的技术实现与组件封装方案。主要包括两种实现方式:**前端打包方案(基于file-saver和jszip)** 和 **后端打包方案**。前者通过前端直接将文件打包为ZIP下载,适合小文件场景;后者由后端生成ZIP文件流返回,适用于大文件或大量文件下载。同时,提供了可复用的Vue组件`BatchDownload`,支持进度条、失败提示等功能。此外,还扩展了下载进度监控和断点续传等高级功能,并针对跨域、性能优化及用户体验改进提出了建议。可根据实际需求选择合适方案并快速集成到项目中。
182 17
|
1月前
|
JavaScript 前端开发 UED
Vue 手风琴实现的三种常用方式及长尾关键词解析
手风琴效果是Vue开发中常见的交互组件,可节省页面空间、提升用户体验。本文介绍三种实现方式:1) 原生Vue结合数据绑定与CSS动画;2) 使用Element UI等组件库快速构建;3) 自定义指令操作DOM实现独特效果。每种方式适用于不同场景,可根据项目需求选择。示例包括产品特性页、后台菜单及FAQ展示,灵活满足多样需求。附代码示例与资源链接,助你高效实现手风琴功能。
105 10
|
1月前
|
JavaScript 前端开发 UED
Vue 表情包输入组件的实现代码:支持自定义表情库、快捷键发送和输入框联动的聊天表情解决方案
本文详细介绍了在 Vue 项目中实现一个功能完善、交互友好的表情包输入组件的方法,并提供了具体的应用实例。组件设计包含表情分类展示、响应式布局、与输入框的交互及样式定制等功能。通过核心技术实现,如将表情插入输入框光标位置和点击外部关闭选择器,确保用户体验流畅。同时探讨了性能优化策略,如懒加载和虚拟滚动,以及扩展性方案,如自定义主题和国际化支持。最终,展示了如何在聊天界面中集成该组件,为用户提供丰富的表情输入体验。
133 8
|
1月前
|
JavaScript 前端开发 UED
Vue 表情包输入组件实现代码及详细开发流程解析
这是一篇关于 Vue 表情包输入组件的使用方法与封装指南的文章。通过安装依赖、全局注册和局部使用,可以快速集成表情包功能到 Vue 项目中。文章还详细介绍了组件的封装实现、高级配置(如自定义表情列表、主题定制、动画效果和懒加载)以及完整集成示例。开发者可根据需求扩展功能,例如 GIF 搜索或自定义表情上传,提升用户体验。资源链接提供进一步学习材料。
82 1
|
1月前
|
JavaScript API 开发者
Vue框架中常见指令的应用概述。
通过以上的详细解析,你应该已经初窥Vue.js的指令的威力了。它们是Vue声明式编程模型的核心之一,无论是构建简单的静态网站还是复杂的单页面应用,你都会经常用到。记住,尽管Vue提供了大量预定义的指令,你还可以创建自定义指令以满足特定的需求。为你的Vue应用程序加上这些功能增强器,让编码变得更轻松、更愉快吧!
38 1
|
1月前
|
存储 JavaScript 前端开发
如何高效实现 vue 文件批量下载及相关操作技巧
在Vue项目中,实现文件批量下载是常见需求。例如文档管理系统或图片库应用中,用户可能需要一次性下载多个文件。本文介绍了三种技术方案:1) 使用`file-saver`和`jszip`插件在前端打包文件为ZIP并下载;2) 借助后端接口完成文件压缩与传输;3) 使用`StreamSaver`解决大文件下载问题。同时,通过在线教育平台的实例详细说明了前后端的具体实现步骤,帮助开发者根据项目需求选择合适方案。
102 0
|
1月前
|
JavaScript 前端开发 UED
Vue 项目中如何自定义实用的进度条组件
本文介绍了如何使用Vue.js创建一个灵活多样的自定义进度条组件。该组件可接受进度段数据数组作为输入,动态渲染进度段,支持动画效果和内容展示。当进度超出总长时,超出部分将以红色填充。文章详细描述了组件的设计目标、实现步骤(包括props定义、宽度计算、模板渲染、动画处理及超出部分的显示),并提供了使用示例。通过此组件,开发者可根据项目需求灵活展示进度情况,优化用户体验。资源地址:[https://pan.quark.cn/s/35324205c62b](https://pan.quark.cn/s/35324205c62b)。
47 0