您的位置:首页 > 科技 > 能源 > 企业网站推广服务_惠州高端网站建设服务_中国新闻今日头条_福州短视频seo

企业网站推广服务_惠州高端网站建设服务_中国新闻今日头条_福州短视频seo

2025/4/23 7:40:01 来源:https://blog.csdn.net/xc917563264/article/details/147273666  浏览:    关键词:企业网站推广服务_惠州高端网站建设服务_中国新闻今日头条_福州短视频seo
企业网站推广服务_惠州高端网站建设服务_中国新闻今日头条_福州短视频seo

Vue 3

关于组件

今天回顾了下2.0关于组件的内容,3.0定义组件的方式多了一种就是通过单文件组件(Single-File Component)的方式将Vue的模板,逻辑和样式放到一个文件中,2.0则不同,它是将模板放到一个属性中,而不是在一个标签里,这样可读性更好,应该也更方便测试。

但代价就是需要使用构建工具,可以把它想象成一个IDE工具,只不过是命令行的形式,需要付出一定的学习成本,我看Visual Studio 2022使用的就是Vite,把它集成进了IDE,即使我不会用Vite也能构建Vue项目,很方便。

也有不依赖构建工具的替代方案petite-vue

Vue对象的参数叫做配置对象

用来显示文本的{{ }}叫做插值语法,是写在标签体之间

在Chrome浏览器上按shift+F5强制刷新页面

在Vue2.0的DevTool中可以下载Vue的开发者工具,Chrome和FireFox的都支持

Vue 2

1、想要使用Vue,首先要创建一个Vue实例,同时要在html中声明一个容器,容器与实例通过选择器进行绑定

2、容器与实例是一一绑定的关系

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

4、{{}}中要写js表达式,它会自动读取到data中的所有属性

v-bind: 可以简写为 :

指令语法

1、写在标签体内部,用于解析标签的属性,内容,事件

数据绑定

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

2、双向绑定(v-model):数据不仅可以从data流向页面,也可以从页面流向data

备注:双向绑定一般应用于表单控件中

v-model:value可以简写为v-model

el的两种语法

1、new Vue的时候配置el属性

2、在Vue实例中调用$mount(""),指定元素

data的两种语法

1、对象式,data作为属性,值是一个对象

2、函数式,data作为属性,值是一个函数

没有用到组件的时候两种都可以,如果用了组件,就只能用函数式,否则会报错。

MVVM模型

M - Model,对应data中的数据

V - View,对应模板,el指定的容器

VM - ViewModel,对应Vue实例对象,起到双向绑定的作用

事件处理

1、使用v-on:xxx或@xxx,xxx是事件名

2、在methods配置的函数是Vue所管理的,所以this指向的是实例对象

3、@click和@click($event)是同一个意思,如果要传递自定义的参数,又想使用event对象,可以这样写
 

事件修饰符

在事件的后面使用点语法,并带上特定的字符串,可以让事件更具多样化。

常用的几个:

1、prevent,阻止事件的默认行为,等同于在事件中使用了event.preventDefault();

2、stop,阻止事件的冒泡,等同于在事件中使用了event.stopPropagation();

3、once,让事件只触发一次,等同于记录了触发次数并在调用前比较了下

键盘事件

为了便于操作,有时候软件需要绑定常用的键盘事件,辅助输入,Vue也做了相应的事情

1、Vue中常用事件的别名:

回车 -> enter;

删除 -> delete;

退出 -> esc;

空格 -> space;

换行 -> tab(特殊,需要配合keydown使用)

2、未提供的别名,可以使用原始的key值绑定,但要写成短横线命名的方式。

3、系统修饰键,ctrl,alt,shift,win在keydown和keyup事件里表现形式不同,在keyup中需按下系统键+其他键,才能触发;在keydown事件中,只需按下系统键就会触发。

4、也可以使用keycode去绑定键盘按键,但不推荐,因为这种方式已经被官方废弃,而且不同的键盘的按键的keycode还不统一。

计算属性

它是通过已有的属性计算得来

底层原理是借助了Object.definepreperty方法提供的getter和setter

get函数什么时候执行?

1、初次加载时执行

2、当依赖的属性发生改变时,重新执行

计算属性与methods相比,由于有缓存机制所以效率更高,多次调用同一个计算属性只执行一次,多次调用同一个methods会计算多次。

如果计算属性要被修改,还需要定义set函数,在set中去修改依赖的属性。

监视属性watch

1、当监视的属性的值发生变化时,它的回调函数立即被调用

2、监视的属性必须存在

3、监视的两种写法:(1)在配置属性中带入watch配置 (2)通过vue的实例调用$watch函数

在watch中配置immediate为true,页面初始化时立即监视。

深度监视

如果需要监视多层级的数据,需要用到深度监视,使用方法是在监视属性中配置deep属性。

计算属性与监视属性的区别

1、computed能完成的功能,watch都可以完成

2、watch能完成的功能,computed不一定能完成,比如watch可以进行异步操作,因为它没有返回值

两个关于函数声明的小原则

1、所有被vue管理的函数,最好写成普通函数,因为这样写this是vue实例或组件实例

2、所有不被vue管理的函数(例如:定时器回调函数,ajax回调函数),最好写成箭头函数,这样写的this是vue实例或组件实例。

绑定样式

绑定class样式的三种写法

写法:class=xxx,xxx可以是字符串,数组,对象

1、字符串写法,适用于类名不确定,需要动态指定

2、数组写法,适用于类型数量不确定,名字也不确定

3、对象写法,适用于数量确定,名字确定,但要动态指定用不用

style样式

:style="{fontSize:xxx}",xxx是动态值。

:style="[a, b]", a和b是样式对象。

条件渲染

有两种方式进行条件渲染:v-show和v-if

使用v-show时,未显示的元素仍然会显示在页面上,只不过display的样式被设置为none,所以在需要频繁切换元素的场景下效率更高。

而使用v-if时,未显示的元素压根不会显示在页面上,但它的优势在于可以配合使用v-else-if,v-else进行比较复杂的逻辑判断,需要注意的是,在使用它们的时候不能被“打断”,否则会出错。

列表渲染

列表渲染使用v-for指令,在需要列表展示的元素上写元素,语法如下:v-for="(item, index) in list" :key=xxx。

它可以遍历:数组,对象,字符串(用的少),指定次数(用的少)

在实际开发中,应使用唯一标示来修饰key,否则在逆序添加,删除等破坏顺序的操作后会引起显示的问题。

收集表单数据

当控件为输入框时,v-model收集的就是value值,不用额外操作。

当控件为单选框时,v-model收集的还是value值,但需要给每个单选框配置value值。

当控件为多选框时,v-model收集的还是value值,不但要给每个多选框配置value值,还需要将data中的承载数据的值的类型设置为数组。(除非是只有一个多选框,这样就不用配置,因为只需要收集true或false,这是它的默认行为)

v-model还有三个点语法的修饰符:

v-model.number:自动进行数值转换

v-model.lazy:延迟数据的收集,在输入时就会发起网络请求的场景会有点用

v-model.trim:自动进行删除前后空格

过滤器

对要显示的数据进行格式化的处理,它适用于一些简单的逻辑。

语法:

1、注册过滤器有两种形式,第一种是局部过滤器,只能在当前Vue实例中使用,格式为:

new Vue({

filters:{

filterName(value){}

}

})

还有一种是全局过滤器,可以在其他的Vue实例中使用,格式为:

Vue.filter("filterName", function(value){

});

2、使用过滤器,语法为:{{ target | filterName }},这种用的比较多,还有一种是在v-bind中使用::x = "target | filterName"

备注:多个过滤器可以并联使用。

内置指令

v-text指令

它的作用是往控件中填充文本。

与插值语法不同的是,它会完全替换文本的内容,插值语法则不会,所以插值语法更加灵活。

v-html指令

它的作用是往控件中填充html内容。

由于可以填充html所以存在安全性问题,容易导致XSS攻击。

不要在用户可以输入的地方使用它。

v-cloak指令

这个指令没有值,它的作用是在网络条件不佳的情况下,不显示让用户摸不着头脑的插值语法。所以用于优化性能。

v-once指令

这个指令也没有值,它的作用是让加载的内容只初始化一次,避免每次都更新它。

v-pre指令

添加了该指令的标签会跳过Vue的编译过程。

可利用它跳过没有插值语法,没有指令语法的节点,加快编译速度。

生命周期

它又称为,生命周期回调函数,生命周期函数,生命周期钩子。

函数名不可更改,可以在里面写业务逻辑。

函数内部的this指向vm实例对象或组件实例对象。

目前学到了8个,4对生命周期钩子,分别是:创建前和已创建,挂载前和已挂载,更新前和已更新,销毁前和已销毁。

常用的生命周期钩子:

1、mounted:发送ajax请求,订阅消息,启动定时器,绑定自定义事件等初始化操作

2、beforeDestroy:在销毁前,应清除定时器,解绑自定义事件,取消消息订阅

关于销毁Vue实例

销毁后自定义事件会失效,但是绑定的DOM事件不会失效。

在beforeDestroy中对数据的操作是无效的,因为不会再触发更新流程了。

组件

非单文件组件

使用组件的步骤:1、创建组件 2、注册组件 3、使用组件

1、如何创建组件

使用Vue.extend(options)创建,其中options和new Vue(options)时传入的参数几乎一致,区别如下:

  • 无需使用el指定容器id
  • data必须写成函数,因为写成函数后再被复用就不会出现重复引用的问题

备注:在声明组件的配置属性中使用template配置组件的结构。

2、如何注册组件

有两种方式,局部和全局的

局部的方式:在new Vue()中传递components选项

全局的方式:Vue.component('组件名', 组件)

3、如何使用组件

在html的容器中,编写<组件名></组件名>标签即可

一些细节

1、组件名

一个单词组成:

第一种写法(首字母小写):school

第二种写法(首字母大写):School

多个单词组成:

第一种写法(带横杠):my-school

第二种写法(大驼峰):MySchool(需要Vue脚手架支持)

备注:

可以在配置项中使用name属性去定义开发者工具中的组件名

2、关于组件标签

第一种写法:<school></school>

第二种写法:<school/>

备注:如果没有使用脚手架工具,第二种写法只会渲染一次

3、简写

const school = Vue.extend(options);

可以简写成

const school = options;

在开发中简写方式更常用哦。

模块化

    // 模块化的三种方式// 1、分别暴露export const school = Vue.extend({});// 2、统一暴露const school2 = Vue.extend({})export {school2}// 3、默认暴露const school3 = Vue.extend({})export default school3// 使用默认暴露时有一个优势,在引入时可以简写import XXX from "xxx"// 使用分别暴露和统一暴露时,需要这样写import {xxx} from "xxx"// 由于Vue.extend可以省略,可以直接写配置对象,所以就变成了上述的形式,这里使用了默认暴露的形式export default({name:"School",data(){return {schoolName: "北京大学",schoolAddress: "北京市海淀区"}}});

创建脚手架

1、配置下载镜像为淘宝的:npm config set registry https://registry.npm.taobao.org

如下系统提示证书过期,还需要执行以下命令,取消SSL认证,npm config set strict-ssl false

2、安装脚手架Vue-Cli,输入命令:npm install -g @vue/cli

3、安装完成后,创建项目,vue create 项目名

4、启动项目,在创建项目时,脚手架会默认带入一个Hello Wrold界面,启动服务:npm run serve,编译完成后会返回地址。

ref属性

1、用来给HTML元素或子组件打标签

2、在获取它们的时候,HTML元素返回DOM,子组件返回实例对象(VC)

3、使用方式:

打标签:<h2 ref="xxx">Hello World</h2>

<School ref="yyy"></School>

获取:this.$refs.xxx或this.$refs.yyy

props配置项

它的工作是将值传给子组件,在开发中也是很常用的。

1、传递数据,定义一个key和value

<Student name="张三"></Student>

如果需要传递数值类型,可以这样写:<Student :age="18"></Student>,在age前面加一个冒号,表示里面的值是一个表达式

2、子组件接收数据

它有三种方式接收数据(以下都是在配置项中定义的),第一种:

props:["name"]

第二种:props:{

// 限制类型

name:String

}

第三种:props:{

name:{

// 限制类型,是否必填,默认值

type:String,

required:true,

default:""

}

}

备注:props是只读的,如果对它进行修改会警告,如果业务需求是得进行修改的,可以在data中定义一个MyName属性,值为name,以后的修改都在MyName中进行就可以。

Scoped样式

作用:让组件的样式局部生效,避免重名带来的冲突

写法:<style scoped></style>

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com