Vue入门(一)

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: Vue入门

初识Vue:

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

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

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

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

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

6.{{xxx}}中的xxx要写js表达式,且xxx可以自动读取到data中的所有属性;

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

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

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

(1). a
(2). a+b
(3). demo(1)
(4). x === y ? ‘a’ : ‘b’

2.js代码(语句)

(1). if(){}

(2). for(){}

代码如下:

<!--准备好一个容器-->
<div id="root">
<h1>Hello,{{name}}</h1></div>
<script type="text/javascript">
Vue.config.productionTip = false //阻止 vue在启动时生成生产提示。
//创建Vue实例
new Vue({
el : '#root', //el用于指定当前Vue实例为哪个容器服务,值通常为css选择器字符串。
data:{ //data中用于存储数据I数据供el所指定的容器去使用,值我们暂时先写成一个对象.
name:'尚硅谷'
}
})
</script>

引入Vue

在html文件中使用script标签引入vue

<!-- 开发环境版本,包含了有帮助的命令行警告 -->
<script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
<!-- 生产环境版本,优化了尺寸和速度 -->
<script src="https://cdn.jsdelivr.net/npm/vue@2"></script>

Vue模板语法

Vue模板语法有2大类:

1.插值语法:

功能:用于解析标签体内容。

写法:{{xxx]},xxx是js表达式,且可以直接读取到data中的所有属性。

2.指令语法:

功能:用于解析标签(包括:标签属性、标签体内容、绑定事件…) .

举例:v-bind :href="xxx”或简写为:href="xx",xxx同样要写js表达式,且可以直接读取到data中的所有属性。

备注: Vue中有很多的指令,且形式都是: v-???,此处只是拿v-bind举个例子。

数据绑定

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

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

备注:

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

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

f70948a4b3ee4bed90998a8de7d49052.png

el与data的两种写法

1.el有2种写法

  • new Vue时候配置el属性。
  • 先创建Vue实例,随后再通过vm.$mount( '#root ')指定el的值。

d828ba7c003d4e75842b0fde8ac73e19.png

2.data有2种写法

  • 对象式:data:{}
  • 函数式:data() { return { }}

注:目前哪种写法都可以,以后学习到组件时,data必须使用函数式,否则会报错。

3899cf5c3d9a4c6c8166aac60cfdc4e6.png

3.一个重要的原则:

由Vue管理的函数,一定不要写箭头函数,一旦写了箭头函数,this就不再是Vue实例了。

mvvm模型

6d2028d422124c8ab0a156e586ca86b4.png


MVVM模型

  • M:模型(Model) : data中的数据
  • V:视图(view):模板代码
  • VM:视图模型(ViewModel): Vue实例

观察发现:

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

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

数据代理

1.vue中的数据代理:

通过vm对象来代理data对象中届性的操作(读/写)

2.Vue中数期代理的好处:

更加方便的方作data中的数据

3.基本原理:

  • 通过object.defineProperty()把data对象中所有属性添加到vm上.
  • 对每一个添加到vm上的属性,都指定一个getter/setter.
  • 在getter/setter内部去操作(读/写)data中对应的属性。

回顾object.defineProperty()

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

事件处理

事件的基本使用:

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

vue中的事件修饰符

Vue中的事件修饰符:

  1. prevent: 阻止默认事件(常用)
  2. stop: 阻止事件冒泡(常用)
  3. once: 事件只触发一次(常用)
  4. capture: 使用事件的捕获模式;
  5. self: 只有event.target是当前操作的元素时才触发事件
  6. passive: 事件的默认行为立即执行,无需等待事件回调执行完毕:

6943aafcd8e84402a2f602006b6e27b6.png

def525a7cf014c82bab13ee872301d9c.png

键盘事件

1.vue中常用的按键别名:

回车 =>enter
删除=> delete(插获"删除”和"退格”键)
退出=>esc
空格=>space
换行=>tab
上 => up
下 => down
左=>left
右= right

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

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

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

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

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

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

计算属性

计算属性:

computed:计算属性

1,定义:要用的属性不存在,要通过己有属性计算得来

2.原理:底层借助了0bjcet.defineproperty方法提供的getter和setter

.3.get函数什么时候执行?

(1).初次读取时会执行一次。

(2).当依赖的教据发生改变时会被再次调用。

4.优势:与methods实现相比,内部有级存机制(复用),效率更高,调试方便。

5.备注:

1.计算属性最终会出现在vm上,直接读取使用即可。

2.如果计算属性要被修改。那必须写set函数去响应修改,且set中要引起计算时依赖的数据发生变化

<div id="root">
        姓:<input type="text" v-model="firstName"><br><br>
        名:<input type="text" v-model="lastName"><br>
        全名:<span>{{fullName}}</span><br><br>
    </div>
    <script>
        Vue.config.productionTip = false
        const vm = new Vue({
            el:'#root',
            data:{
                firstName:"张",
                lastName:'三'
            },
        //     计算属性
            computed:{
                fullName:{
                    // get有什么用?当有人读取fullName时,get就会被调用,且返回值就作为fullName的值
                    // get什么时候调用?1.初次读取fullName时,2.所依赖的数据发生变化
                    get(){
                        console.log('get就被调用');
                        return this.firstName + '-' + this.lastName
                    },
                    // set什么时候调用?当fullName被修改时
                    set(value){
                        console.log('set',value);
                        const arr = value.split('-')
                        this.firstName = arr[0]
                        this.lastName = arr[1]
                    }
                }
            }
        })
    </script>

侦听属性

监视属性watch:

1.当被监视的属性变化时,回调函数自动调用,进行相关操作

2.监视的属性必须存在,才能进行监视!!

3.监视的两种写法:

(1).new vue时传入watch配置

(2).通过vm.$watch监视

深度监视:

(1).Vue中的watch默认不监测对象内部值的改变(一层)

(2).配置deep:true可以监测对象内部值改变(多层)

备注:

(1).Vue自身可以监测对象内部值的改变,但Vue提供的watch默认不可以!

(2).使用watch时根据数据的具休结构,次定是否采用深度监视

computed利lwatch之间的区别:

  • computed能完成的功能。 watch都可以完成
  • watch能完成的功能,computed不一定能完成,例如: watch可以进行异步操作。

两个重要的小原则:

  • 所被Vue管理的函数,最好写成普通函数,这样this的指向才是vm或组件实例对象。
  • 所有不被Vue所管理的两数(定时器的回调函数、ajax的回调函数,promise的回调函数等),最好写成箭头函数,这样this的指向才是vm域组件实例对象。

绑定样式

绑定样式

class样式

  • 写法:class= ’xxx' xxx可以是字符串、对象、数组
  • 字符串写法适用于:类名不确定,要动态获取

4c1aecc8b3744032885a0f7b864fe2b6.png

edda3d3c518340ca92f8936138f46b16.png

  • 对象写法适用于:要绑定多个样式,个数不确定,名字也不确定。

7c011987db28498e93e07d4ac7db857a.png

684ccf6cea2a446d9bd75b0d0e46cc34.png

  • 数组写法适用于:要绑定多个样式,个数确定,名字也确定,但不确定用不用。

d67a69adf3e64dab9adc8c80e26d1bc6.png

7db1bfb72ee74baa9f5fec5bfcbbc020.png

style样式

style="{fontSize: xxx}”其中xxx是动态值
style="[a,b]"其中a、b是样式对象。

3c856571048648fcbf9697bfd3fec732.png

5861c16729df49adbfca5074b7862309.png

条件渲染:

1.v-if

写法:

(1).v-if="表达式”
(2).v-else-if="表达式"
(3).v-else="表达式"

适用于:切换频率较低的场景。

特点:不展示的DOM元素直接被移除。

注意: (1)v-if可以和: v-else-if、v-else一起使用,但要求结构不能被“打断”。

(2)template标签不影响结构,页面html中不会有此标签,但只能配合v-if,不能配合v-show

2.v-show

写法:v-show=“表达式”

适用于:切换频率较高的场景。

特点:不展示的DOM元素未被移除,仅仅是使用样式隐藏掉

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

3v-for指令

  • 用于展示列表数据
  • 语法: <li v-for="(item,index) of items" :key="index"></li>,这里key可以是index,更好的是遍历对象的唯一标识
  • 可遍历:数组、对象、字符串(用的少)、指定次数(用的少)

vue监听数据

vue监视数据的原理:

1.vue会监视data中所有层次的数据。

2.如何监测对象中的数据?

通过setter实现监视,且要在new Vue时就传入要监测的数据。

  • 对象中后追加的属性,Vue默认不做响应式处理
  • 如需给后添加的属性做响应式,请使用如下API:
Vue.set(target.propertyName/index,value)或
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的根数据对象添加属性!!

收集表单数据

若: <Input type="text" />.则v-model收集的是value值、用户愉入的就是value值。
若: <input type="radio" />。则v-mode1收集的是value值,且要给标签配置value值.
若:<input type="checkbox" />

1.没有配置input的value属性,那么收集的就是checked(勾选or未勾选,是布尔值)

2.配置input的value属性:

(1)v-model的初始值是非数组,那么收集的就是checked(勾选 or 未勾选,是布尔值)

(2)v-model的初始值是数组,那么收集的的就是value组成的数组

备注:

:v-model的三个修饰符:

lazy:失去焦点再收集数据

number:输入字符串转为有效的数字

trim:输入首尾空格过滤

过滤器

过滤器:

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

语法:

1.注册过滤器:

全局过滤器:Vue.filter(name,callback)或局部过滤器:new Vue{filters:{}}

2.使用过滤器:{{ xxx│过滤器名}或v-bind:属性=“xxx|过滤器名"

备注:

1.过滤器也可以接收额外参数、多个过滤器也可以串联

2.并没有改变原本的数据,是产生新的对应的数据

vue内置指令

v-text

v-text指令:

1.作用:向其所在的节点中渲染文本内容-

2.与插值语法的区别:v-text会替换掉节点中的内容,{{xx}}则不会-

v-html

v-html指令:

1.作用:向指定节点中渲染包含html结构的内容。

2.与插值语法的区别:

(1).v-html会替换掉节点中所有的内容,{{xx}则不会。

(2).v-html可以识别html结构。

3.严重注意: v-html的安全性问题!!!

(1).在网站上动态渲染任意HTML是非常危险的,容易导致XSS攻击。

(2).一定要在可信的内容上使用v-html,永不要用在用户提交的内容上!

v-cloak

v-cloak指令(没有值):

1.本质是一个特殊属vue实例创建完毕并接管容器后,会删掉v-cloak属性。

2.使用css配合v-cloak可以解决网速慢时页面展示出{{XXX]}的问题。

v-once

v-once指令:

1.vonce所在节点在初次动态渲染后,就视为静态内容了。

2.以后数据的改变不会引起v-once所在结构的更新,可以用于优化性能。

v-pre

v-pre指令;

1.跳过其所在节点的编译过程-

2.可利用它跳过:没有使用指令语法、没有使用插值语法的节点,会加快编译。

自定义指令

自定义指令总结:

一.定义语法:

1).局部指令;

new Vue({
directives:{指令名;配置对象}
}

}或

new Vue({
directives{指令名:回调函数}
})

(2).全局指令:

Vue.directive(指令名,配置对象)或 Vue.directive(指令名,回调函数)

二、配置对象中常用的3个回调:

(1).bind:指令与元素成功绑定时调用。

(2).inserted:指令所在元素被插入贝面时调用

(3).update:指令所在模板结构被重新解析时调用。

三、注意:

1.指令定义时不加v-,但使用时要加v-:

2.指令名如果是多个单词,要使用kebab-case命名方式,不要用camelCase(驼峰命名法)命名。

生命周期

生命周期:

1.又名:生命周期回调函数、生命周期函数、生命周期钩子

2.是什么:Vue在关键时刻帮我们调用的一些特殊名称的函数。

3.生命周期函数的名宁不可更改。但函数的具体内容是程序员根据需求编写的

4.生命周期函数中的this指向是vm或组件实例对象

常用的生命周期钩子:

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

2.beforeDestroy:清除定时器、解绑自定义事件、取消订阅消息等【收尾工作】。

关于销毁Vue实例

1.销毁后借助Vue开发者工具看不到任何信息-

2.销毁后自定义事件会失效,但原生DOM事件依然有效-

3.一般不会再beforeDestroy操作数据。因为即便操作数据。也不会再触发更新流程了

Vue组件化

基本使用

Vue中使用组件的三大步骤:

1.定义组件(创建组件)

2.注册组件

3.使用组件(写组件标签)

一、如何定义一个组件?

使用Vue.extend(options)创建,其中options和new Vue(options)时传入的那个options几乎一样,但也有点区别;

区别如下:

1.el不要写,为什么? —最终所有的组件都要经过一个vm的管理,由vm中的el决定服务哪个容器。

2.data必须写成函数,为什么? —避免组件被复用时,教据存在引用关系。

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

二、如何注册组件?

1.局部注册:new Vue的时候传入components选项

2.全局注册:

Vue.component('组件名",组件)

三、编写组件标签:

<school></school>或<school/>

注意点:

1.关于组件名:

(1)一个单词组成:

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

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

(2)多个单词组成:

第一种写法(kebab-case命名):my-school

第二种写法(CamelCase命名):Myschool(需要Vue脚手架支持)

备注:

(1).组件名尽可能回避HTML中己有的元素名称,例如: h2、H2都不行。

(2).可以使用name配置项:指定组件在开发者工具中呈现的名字

2.关于组件标签:

第一种写法:

<school></school>

第二种写法

<school/>

备注:不用使用脚手架时,<school/>会导致后续组件不能渲染-

关于VueComponent:

1.school组件本质是一个名为VueComponent的构造函数,且不是程序员定义的,是Vue.extend生成的

2.我们只需要写<school/>或<school></school>,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

  • 一个重要的内置关系: VueComponent.prototype._proto_ === Vue.prototype
  • 为什么要有这个关系:让组件实例对象(vc)可以访问到Vue原型上的属性、方法。

单文件组件

关于不同版本的Vue:

1.vue.js 与vue.runtime .xxx.js的区别:

(1).vue.js是完整版的Vue,包含:核心功能+模板解析器。

(2).vue.runtime.xxx.js是运行版的Vue,只包含:核心功能;没有模板解析器。

2.因为vue.runtime.xxx.js没有模板解析器,所以不能使用template配置项,需要使用render函数接收到的createElement函数去指定具体内容。

脚手架结构

|-= node_modules
|--public
| |- favicon.ico:页签图标
| |- index.html :主页面
|-- src
| |-- assets:存放静态资源
| |  L- logo.png
| |-- component:存放组件
| | L-- HelloMorld.vuel
| |-- App.vue:汇总所有组件
| |-- main.js:入口文件
|-- .gitignore: git版本管制忽略的配置
|--babe1.config-js: babel的配置文件
|—- package.json:应用包配置文件
|-- README.md:应用描述文件
|-- package-lock.json:包版本控制文件

ref属性

1.被用来给元素或子组件注册引用信息(id的替代者)

2.应用在htm1标签上获取的是真实DOM元素。应用在组件标签上是组件实例对象(vc)

3.使用方式:

打标识:

<h1 ref="xxx">.....</h1>或<School ref="xxx"></School>获取: this.$refs.xxx

配置项props

功能:让组件接收外部传过来的数据

(1).传递数据:

<Demo name="xxx"/>

(2).按收数据:

第一种方式(只接收):

props:['name']

第二种方式〔限制类型):

props:{
          name : String
        }

第三种方式〔限制类型、限制必要性、指定默认值):

props:{
          name:{
            type:string,//类型required:true,/必要性default:'老王’/默认值}
          }
        }

备注: props是只读的,Vue底层会监测你对props的修改,如果进行了修改,就会发出警告,若业务需求确实需要修改,那么请复制props的内容到data中一份,然后去修改data中的数据

插件

功能:用于增强Vue

本质:包含install方法的一个对象,install的第一个参数是Vue,第二个以后的参数是插件使用者传递的数据。

定义插件:

对象.install = function (vue,options)

1.添加全局过滤器

vue.filter(....)

2.添加全局指令

Vue.directive(....)

3.配置全局混入(合)

Vue.mixin(... .)

添加实例方法

vue.prototype.$myMethod = function () {...}
    vue.prototype. $myProperty = XXXX
    }

使用插件: Vue.use()

scope样式

作用:让样式在局部生效。防止冲突

写法: <style scoped>

todolist案件总结

256ee765279b481fa0225278cd163911.png

1.组件化编码流程:

(1).拆分静态组件:组件要按照功能点拆分,命名不要与htrnl元,素冲突。 (2).实现动态组件:考虑好数据的存放位置,数据是一个组件在用,还是一些组件在用:

1).—个组件在用:放在组件白身即可。

2).一些组件在用:放在他们共同的父组件上(状态提升)。

3).实现交互:从绑定事件开始。

props适用于:

(1).父组件==>子组件通信

(2).子组件==>父组件通信〔要求父先给子一个函数)

3.使用v-model时要切记: v-model绑定的值不能是props传过来的值,因为props是不可以修改的!

props传过来的若是对象类型的值,修改对象中的属性时Vue不会报错,但不推荐这样做。


目录
相关文章
|
6天前
|
JavaScript 前端开发
如何在 Vue 项目中配置 Tree Shaking?
通过以上针对 Webpack 或 Rollup 的配置方法,就可以在 Vue 项目中有效地启用 Tree Shaking,从而优化项目的打包体积,提高项目的性能和加载速度。在实际配置过程中,需要根据项目的具体情况和需求,对配置进行适当的调整和优化。
|
7天前
|
存储 缓存 JavaScript
在 Vue 中使用 computed 和 watch 时,性能问题探讨
本文探讨了在 Vue.js 中使用 computed 计算属性和 watch 监听器时可能遇到的性能问题,并提供了优化建议,帮助开发者提高应用性能。
|
7天前
|
存储 缓存 JavaScript
如何在大型 Vue 应用中有效地管理计算属性和侦听器
在大型 Vue 应用中,合理管理计算属性和侦听器是优化性能和维护性的关键。本文介绍了如何通过模块化、状态管理和避免冗余计算等方法,有效提升应用的响应性和可维护性。
|
7天前
|
存储 缓存 JavaScript
Vue 中 computed 和 watch 的差异
Vue 中的 `computed` 和 `watch` 都用于处理数据变化,但使用场景不同。`computed` 用于计算属性,依赖于其他数据自动更新;`watch` 用于监听数据变化,执行异步或复杂操作。
|
6天前
|
JavaScript 前端开发 UED
vue学习第二章
欢迎来到我的博客!我是一名自学了2年半前端的大一学生,熟悉JavaScript与Vue,目前正在向全栈方向发展。如果你从我的博客中有所收获,欢迎关注我,我将持续更新更多优质文章。你的支持是我最大的动力!🎉🎉🎉
|
8天前
|
存储 JavaScript 开发者
Vue 组件间通信的最佳实践
本文总结了 Vue.js 中组件间通信的多种方法,包括 props、事件、Vuex 状态管理等,帮助开发者选择最适合项目需求的通信方式,提高开发效率和代码可维护性。
|
6天前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。自学前端2年半,熟悉JavaScript与Vue,正向全栈方向发展。博客内容涵盖Vue基础、列表展示及计数器案例等,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
|
8天前
|
存储 JavaScript
Vue 组件间如何通信
Vue组件间通信是指在Vue应用中,不同组件之间传递数据和事件的方法。常用的方式有:props、自定义事件、$emit、$attrs、$refs、provide/inject、Vuex等。掌握这些方法可以实现父子组件、兄弟组件及跨级组件间的高效通信。
|
13天前
|
JavaScript
Vue基础知识总结 4:vue组件化开发
Vue基础知识总结 4:vue组件化开发
|
13天前
|
存储 JavaScript
Vue 状态管理工具vuex
Vue 状态管理工具vuex