2:vue2.0基础知识点总结

一、环境搭建

最快速最便捷的方式是通过vue脚手架vue-cli来搭建

全局下载vue-cli脚手架

也可以通过指定版本号来下载 cnpm i -g @vue/cli@3.1.1

如果vue的版本不一致,可以通过uninstall来卸载重新安装 npm uninstall -g @vue/cli

二、创建并运行项目

通过vue create 项目名来创建项目
进入文件夹并启动服务

三、模板语法

模板语法出自“胡子语法”,在props属性或者data方法里面定义变量,然后在模板中用{{变量名}}来使用这个变量,或者用v-html指令来使用包含html标签的变量,像class、id等特性得用v-bind:id(:id)/v-bind:class(:class)来使用变量,同时在模板中还可以使用表达式。

3.1 文本

在data方法中定义text变量,在模板中用{{text}}来使用它
浏览器中会出现这个文本

3.2 html标签

当变量中有html标签时,通过v-html来渲染变量,可以识别标签,而不会把它当成字符串直接渲染出来
可以识别出i标签并显示斜体样式

3.3 class、id等渲染

id、class这些渲染的时候要用v-bind指令的方式

3.4 语句

vue中可以使用单个表达式
单个表达式

3.5 指令

指令指的是带有v- 前缀的特殊attribute,vue中常见指令有v-if/v-else、v-show、v-hide、v-once、v-bind、v-on、v-for。

还有一个特殊的用法是自定义指令,建一个js文件,引入vue,使用vue.directive方法来创建一个自定义指令,directive方法传入两个参数,第一个参数为自定义指令名,第二个参数为对象,对象里可以使用钩子函数(binding、inserted、update、componentUpdated、unbind),这些钩子函数有四个参数(el、binding、vnode、oldVnode)。使用的时候引入这个js文件,然后在模板中通过v-指令名来调用。如下所示:

创建n.js并通过directive方法来创建自定义指令
导入这个指令
通过v-指令名来使用自定义指令,这里通过v-n

3.6 修饰符

3.7 缩写

v-bind:href  可以写成 :href   |   v-on:click 可以写成 @click

四、样式与遍历

4.1 计算属性  使用于具有依赖关系的数据监听

一般当有数据变化会带来其他数据变化的时候,是用回调函数来操作的,当某某变完改变另一个,在vue中则是由计算属性来完成,相当于vue自己的回调。

在computed写计算属性,具有依赖关系的数据监听

4.2 类与样式

4.2.1 数组方式:适合较少的class

代码中通过数组的方式来给class赋值
dom结构中显示的结果

4.2.2 对象方式:适用于比较多的class名或者动态class

可以直接赋值给class一个对象,属性值是字符串也就是class名,属性值是定义的变量为布尔值;也可以赋值给class一个变量,这个变量是在props传过来的或者data方法中定义的一个对象变量,同样的这个对象的属性名是class名,属性值为布尔值。如下所示

4.2.2.1 直接在class里面写对象

传给class的是一个对象,其中a3、a4是定义在data里面的布尔值,如上a3为true,所以test-3这个属性名起作用,而a4为false,所以test-4不起作用


dom结构中只显示test-3

4.2.2.2 对象变量的方式

传给class的是一个在data里定义的styleObj变量,这个变量是一个对象元素,属性值即为类名,属性值为布尔类型
dom中显示test-5的类名


4.3 条件&列表渲染

条件:v-if/v-else/v-else-if   用于根据条件来判断是否渲染一块内容

数组列表渲染: v-for指令

通过v-for来循环渲染一个数组,:key来定义唯一的key值,提升效率
循环渲染

也可以引用数组的下标

通过在v-for里面用(item,ind)的方式来声明下标,然后就可以使用了
这里的a,0 b,1就是对应上面的 {{item}},{{ind}}

对象列表渲染: v-for也可以用来渲染对象,如果直接传一个参数,那就是对象属性值,如果用(value,key)这样的方式来循环渲染,第一个参数value是对象属性值,第二个key是对象属性名

对象渲染一个参数

这里的value就是对象objList里面的各个属性值
{{value}}渲染的就是三个属性值,张三  20  女 
列表渲染对象,第一个参数为对象的属性值,第二个参数为对象的属性名
渲染对象

分组用法 复杂模板的分组条件处理的方式

可以用template来进行分组渲染,注意这里的:key就不能写在template上面了,因为其实tempate其实在dom中是不存在的,写在template的子级元素上
分组渲染的结果

五、事件处理

5.1 定义与缩写

vue中通过v-on:来监听dom事件,比如v-on:click

通过v-on监听dom事件,事件方法写在methods里面

v-on可以用简写@来代替

这里的@click就相当于上面的v-on:click

5.2 内联写法

除了上面的直接给v-on事件绑定一个方法外,还有一种内联的写法来通过:方法名(参数1、参数2),这种方式来调用,参数1就是 传递的参数,参数2是触发事件的dom元素。如下所示:

通过内联写法,传递参数‘hello world’给参数str
点击button,触发这个say方法,可以看到控制台打印出:你好啊世界hello world
可以看到这里传了两个参数,第一个是str字符串,第二个$event是触发事件的dom对象,注意这里必须写成$event,否则的话会报错
可以看到这里显示触发事件的是button

5.3 事件修饰符

vue中提供了修饰符来实现之前的event.preventDefault()这种功能。常见的修饰符有.stop(阻止单击事件继续传播) 、.prevent(阻止默认行为)、.once(只执行一次)、.self(只有触发元素是自身时才调用函数)、.passive(不阻止默认行为,所以不可以与.prevent同时使用)、.capture(先在此处理,再交由内部元素处理-----有点懵啥意思啊)。

如下:因为button是div的子元素,点击button触发fn1,事件冒泡也会触发父元素div的点击事件调用say这个函数,但是因为用了.stop这个修饰符,阻止了单击事件继续传播,所以这里点击button的时候查看控制台只会看到输出222,不会调用say这个函数。

用.stop修饰符阻止单击事件继续传播
点击图片中的button控制台中只会打印222

六、组件

6.1 props:组件的参数传递  父组件传给子组件

在父组件中定义一个变量posts,这个变量是一个数组,父组件中引用了子组件child,这里还用v-for指令进行了循环,将循环的每一个元素设置为post属性,传给了子组件child

父组件通过  :post  这个属性向子组件child传递了posts循环遍历的每一个对象子元素post
在子组件的props中声明一下传过来的post属性
可以看到子组件渲染出来了

6.2 自定义事件 :子组件向父组件通信

上面的是父组件向子组件通信,子组件向父组件通信可以通过自定义事件的方式来进行

子组件中通过$emit的方法来向父组件发出一个事件,第一个参数addCount是事件名,第二个this.num是传给这个事件的参数,参数值为子组件定义的变量num(20)
在父组件中的methods对象中写这个方法,@事件名自定义事件的方式在引用子组件的地方来调用,这里是@addCount='addCount'

6.3 slot:插槽在组件抽象设计中的应用

如果希望父组件调用子组件中有一部分父组件调用的不同则显示内容不同,这里可以使用slot插槽来实现

首先在子组件中放置slot插槽来决定在哪里父组件可以替换,比如这里的<slot></slot>放在div和button之间,那么父组件中调用子组件时在子组件中写的内容就会替换这个slot所占的位置
这里父组件在调用子组件时在子组件中加了这个p标签,正常情况下这个p标签是不会显示的,但是因为上图中子组件中使用了<slot></slot>所以这个p标签的内容会显示出来


可以看到这个p标签显示出来了并且位置就是slot插槽在子组件中的位置,在div和button中间

如果想要使用多个插槽,可以在子组件中放置插槽的时候给插槽添加name属性,父组件中调用子组件的时候放置插槽替换内容的时候,在替换内容里通过slot=“插槽的name值”就可以了。

子组件中定义了两个插槽,分别是第4行的name为firstSlot的插槽和第8行name为secondSlot的插槽
父组件调用子组件child的时候在child里面写了两个p标签分别是slot为firstSlot的和slot为secondSlot的来代替上图中子组件的那两个slot
可以看到替换的位置与子组件中slot的位置相同

七、路由

通过vue create 项目名来创建的项目并没有自动配置使用vue-router,所以当项目需要使用的时候,需要如下步骤:

1、下载vue-router

通过cnpm i vue-router来下载vue-router

2、新建pages文件夹,并编写测试页面组件a.vue和b.vue

添加页面组件

3、创建router.js文件,创建vue-router实例,并且在vue中使用vue-router

导入vue、vue-router还有页面组件,通过vue.use来使用vue-router,再通过new关键字来创建一个vue-router实例并配置这个实例的routes选项,最后将这个实例通过export导出

4、在main.js中将这个vue-router实例挂载到vue实例上去

导入router.js文件(这个文件导出对象是一个vue-router实例),再将其挂载到vue实例上去

5、这时候会发现控制台会报runtime的错误,这是因为项目默认是只能实时运行而不同模板渲染的,想要通过路由必须要在vue的配置文件中将runtimeCompiler选项设置为true,但是项目中并没有这个配置文件,所以得手动创建一下vue.config.js文件,并且配置一下。如下:

创建vue.config.js文件(注意这个文件与项目的package.json文件平行),配置runtimeCompiler为true

6、修改public文件夹下面的index.html,引入router-view组件和router-link组件,router-view是用来占位显示router-link中的to属性指向的页面,每当点击router-link组件,router-link的to属性中指向的页面就会显示在router-view的位置,注意这个to属性配置的路径得和上面3的vue-router实例中配置的routes数组值得对象的path属性相同。

index.html中添加router-view和router-link内置组件
注意看上面的router-link中的to里的 "/a"和“/b”,和这里的path配置的路径是一致的
点击第一个router-link,会发现中间出现了a页面

八、vuex基础

8.1 基础使用

1、下载vuex

通过 cnpm i vuex来下载vuex

2、新建vuex的文件,在vue中使用vuex,并创建vuex的Store实例,配置state、mutations、actions等然后导出

新建store文件夹,在该文件夹下新建index.js,引入vue和vuex并通过use方法来在vue中使用vuex,通过new Vuex.Store来创建vuex的Store实例(注意这里的new Vuex.Store的S必须大写,否则会报错),配置完state、mutations、actions等然后通过export来导出这个模块

3、在main.js中将vuex的Store实例挂载到全局vue实例上去,这样全局都可以使用了

导入store实例,并挂载到全局

4、组件中使用

用mapActions相当于this.dispatch

8.2 vuex模块化

vuex中可以使用modules来对vuex的状态进行模块化管理

1、在store文件夹下面创建modules文件夹,并编写money模块和count模块,并将其导出

将模块导出

2、在store的index.js的vuex的store实例中的modules属性中导入各个模块

注意到这里都不用再写state、mutations、actions这些了,因为在模块中都写了,只需要用modules来导入各个模块就可以了

3、组件中使用state中的变量需要用模块的state变量名的方式,触发方法需要在前面指定是属于哪个vuex模块的

使用变量中第一个count是模块名,第二个count指的是count模块中state定义的状态count;方法里前面加个count表明是count模块中的add操作和reduce操作,不像之前直接是个数组里面写add、reduce方法名

4、传参在组件中传参,在mutations和actions中声明一下参数

add用了内联的写法,传了参数3给add方法
在mutations和actions里的add方法中都声明了参数param
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,937评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,503评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,712评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,668评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,677评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,601评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,975评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,637评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,881评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,621评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,710评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,387评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,971评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,947评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,189评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,805评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,449评论 2 342

推荐阅读更多精彩内容

  • Vue 实例 属性和方法 每个 Vue 实例都会代理其 data 对象里所有的属性:var data = { a:...
    云之外阅读 2,198评论 0 6
  • 1. Vue 实例 1.1 创建一个Vue实例 一个 Vue 应用由一个通过 new Vue 创建的根 Vue 实...
    王童孟阅读 1,013评论 0 2
  • 每个 Vue 应用都是通过用 Vue 函数创建一个新的 Vue 实例开始的: 实例生命周期钩子 每个 Vue 实例...
    Timmy小石匠阅读 1,371评论 0 11
  • Vue.js特性:渐进式技术栈 轻量级的框架 双向数据绑定 指令 插件化 Vue实例书写模板: 访问Vue实例的属...
    猫晓封浪阅读 1,344评论 0 0
  • 很少跟人提及这段放牛的童年经历,要不是在寿文和梦轲老师2天的《静默之爱工作坊》中遇到村长Jerry,他屡屡回忆起小...
    哈里Jimmy阅读 394评论 3 2