到了2.0以后,有哪些变化:

  1. 在每个组件模板,不在支持片段代码

之前:

<template id=”aaa”>

<h3>我是组件</h3><strong>我是加粗标签</strong>

</template>

现在:  必须有根元素,包裹住所有的代码

<template id="aaa">

        <div>

         <h3>我是组件</h3> <strong>我是加粗标签</strong>

        </div>

</template>

2、关于组件定义

之前:、

Vue.extend 这种方式,在2.0里面有,但是有一些改动,这种写法,即使能用,咱也不用——废弃

Vue.component(组件名称,{                  在2.0继续能用

data(){}

methods:{}

template:

});

现在: 2.0推出一个组件,简洁定义方式:类似于Vue.extend()

var Home={

template:'#aaa'

};

 Vue.component('my-aaa',Home);

3、关于生命周期

之前:

created:       当new Vue执行后,即实例已经创建时执行

beforeCompile:当开始编译HTML页面所有的Vue语法之前执行

compiled:     当编译HTML页面所有的Vue语法结束之后执行

ready:       当编译结束后把所有元素挂到Dom树,即插入到文档中后执行

beforeDestroy : 销毁之前

destroyed :     销毁之后

现在:

beforeCreate 组件实例刚刚被创建,属性都没有

created        实例已经创建完成,属性已经绑定

beforeMount 模板编译之前,页面的{{}}未替换

mounted 模板编译之后,代替之前ready  *

beforeUpdate 组件更新之前

updated 组件更新完毕 *

beforeDestroy 组件销毁前

destroyed 组件销毁后

4、关于生命周期v-for

2.0里面默认就可以添加重复数据,不需要使用track-by='$index/uid'

去掉了隐式一些变量   $index $key

之前:                    index表示下标,val表示当前的值

v-for="(index,val) in array"     

现在:

v-for="(val,index) in array"

track-by="id" 变成      <li v-for="(val,index) in list" :key="index">

5、自定义键盘信息

之前:

Vue.directive('on').keyCodes.ctrl=17;

现在:

 Vue.config.keyCodes.ctrl=17

6、关于过滤器,推荐自定义写法

之前:

系统就自带很多过滤

{{msg | currency}}   {{msg | json}}   limitBy    filterBy

到了2.0, 内置过滤器,全部删除了,

推荐使用lodash 工具库

自定义过滤器——还有 但是,自定义过滤器传参变化

之前: {{msg | toDou '12' '5'}}

现在: {{msg | toDou('12','5')}}

7、关于父子组件直接的数据交互

子组件想要拿到父组件数据:   通过  props

之前:

子组件可以更改父组件信息,可以是同步  sync

现在:

不允许直接给父级的数据,做赋值操作

解决办法:

a). 父组件每次传一个对象给子组件, 对象之间引用 。将数据变成对象

b). 只是不报错, mounted中转,将数据赋值后更改,不直接更改

8、可以单一事件管理组件通信: vuex

在全局定义一个vue对象

var Event=new Vue();

在发送出数据的组件内定义一个方法,点击触发。调用vue对象中的$emit

      send(){   Event.$emit ('a-msg',this.a);  }

   Event.$emit(事件名称, 数据)

在接收数据的组件中调用调用vue对象中的$on进行接收数据

    Event.$on('a-msg',function(a){

                     this.a=a;

                 }.bind(this));

Event.$on(事件名称,function(data){

//data

}.bind(this));

9、动画过渡

之前: transition 作为一个属性使用

HTML元素:<p transition="fade"></p>

定义CSS:.fade-transition{}

.fade-enter{}

.fade-leave{}

现在:transition 作为一个组件HTML标签

<transition name="fade">

需要运动的对象(可以是元素,属性、路由....)

</transition>

定义CSS:

.fade-enter{}         //初始状态,即目标元素原本的状态

.fade-enter-active{}   //变化成什么样  ->  当元素出来(显示)的时候的状态

.fade-leave{}         //离开前的状态

.fade-leave-active{}  //变成成什么样   -> 当元素离开(消失)的时候的状态

例子:

<transition name="fade"><p v-show="show"></p> </transition>

  .fade-enter-active, .fade-leave-active{   //定义总的动画时间

            transition: 1s all ease;

        }

    .fade-enter,.fade-leave{             //动画前的状态

            opacity:0;

            width:100px;

            height:100px;

        }

        .fade-enter-active{         //目标元素出现(显示)时的动画

            opacity:1;

            width:300px;

            height:300px;

        }

        .fade-leave-active{   //目标元素消失(隐藏)时的动画

            opacity:0;

            width:100px;

            height:100px;

        }

transition内部具备多个方法函数:后面跟的·是一个方法

@before-enter="beforeEnter"        显示前触发

@enter="enter"                      显示时触发

@after-enter="afterEnter"            显示后触发

@before-leave="beforeLeave"        消失前触发

@leave="leave"                      消失时触发

@after-leave="afterLeave"            消失后触发

方法名不可改变,每个方法函数可传入el值,表示当前动画对象

例子:

 <transition name="fade @before-enter="beforeEnter" >

  </transition>
  methods:{

          beforeEnter(el){         //定义动画之前的方法,el表示动画对象

                console.log('动画enter之前');

                    },

        }

如何animate.css配合用?

直接在transition标签内调用animate.css的class样式

<transition enter-active-class="bounceInLeft"   leave-active-class="bounceOutRight">

       <p v-show="show" class="animated"></p>   //调用animated

</transition>

当一个transition内有多个元素需要使用动画时,使用transition-group,并且使用 :key 标注顺序

例子一:

    <transition-group enter-active-class="zoomInLeft" leave-active-class="zoomOutRight">

            <p v-show="show" class="animated" :key="1"></p>

            <p v-show="show" class="animated" :key="2"></p>

   </transition-group>

例子二:

<transition-group enter-active-class="zoomInLeft" leave-active-class="zoomOutRight">

    <p v-show="show" class="animated" v-for="(val,index) in lists" :key="index">

            {{val}}

     </p>

 </transition-group>

10、关于路由

基本使用:

1.  布局

<router-link to="/home">主页</router-link>      //不再使用a标签

<router-view></router-view>

2. 路由具体写法

//声明各个组件

var Home={

    template:'<h3>我是主页</h3>'

};

var News={

    template:'<h3>我是新闻</h3>'

};

//配置路由对应的组件

const routes=[

    {path:'/home', componet:Home},

    {path:'/news', componet:News},

];

//生成路由实例

const router=new VueRouter({

    routes                    //相当于routes :routes

});

//最后挂到vue上

new Vue({

    router,                     //相当于 router:router

    el:'#box'

});

3. 重定向redirect

之前  router.rediect  废弃了

{path:'*', redirect:'/home'}             

//  *表示任何一个路由链接,当找不到路由的情况下也会跳转到这个位置

路由嵌套 : children

<router-link to="/user/username">跳转到子路由</router-link>

const routes=[                     //配置路由对应的组件

    {path:'/home', component:Home},

    {

        path:'/user',

        component:User,

        children:[                     //写在嵌套的路由里面,使用children

            {path:'username', component:UserDetail}

        ]

    },

    {path:'*', redirect:'/home'}              //404错误默认跳转

];

路由之间的数据携带:$route.params

<router-link to="/user/strive/age/10">Strive</router-link>   //注意链接{path:':username/age/:age', component:UserDetail} //使用:表示携带数据

<div>{{$route.params}}</div>   //页面展示该路由携带的数据

路由实例方法:  表现为是否产生历史记录

router.push({path:'home'});   //直接添加一个路由,表现切换路由,本质往历史记录里面添加一个

router.replace({path:'news'})          //替换路由,不会往历史记录里面添加

例子:

 methods:{

                push(){    router.push({path:'home'});      },

                replace(){  router.replace({path:'user'});   }

            }

给路由切换添加动画:使用animate.css

直接将 <router-view></router-view>放在transition 标签内

例子:

<transition enter-active-class="animated bounceInLeft" leave-active-class="animated bounceOutRight">

                <router-view></router-view>

 </transition>

11、关于脚手架

添加路由命令:npm install vue-router --save

main.js文件内发生变化,本质上没有区别,其他都一样写法

之前:

new Vue({

   el: '#app',

   components:{App}

})

现在:

new Vue({

  el: '#app',

  render: h => h(App)

})

在vue-loader里面为路由添加动画

1、直接在index.html页面引入

2、在main.js顶部引入,直接打包成一个文件

注意:需要另外按照style-loader  css-loader两个模块

命令行:npm install style-loader css-loader

并在webpack.config.js文件中配置

   {

        test: /\.css$/,

        loader: 'style!css'                 //顺序定死的

      }

例子:

import './assets/css/animate.css';

12、关于与后台的数据交互

推荐使用axios

跟vue-resourse使用方式完全一样

命令行安装:npm install axios --save-dev

页面引入:  import axios from “axios”

Vue版本过渡变化的更多相关文章

  1. Vue响应式变化

    Vue有一个很方便的特性就是Vue的双向绑定,即响应式变化,在Vue2.X版本中,Vue响应式变化靠的是Object.defineProperty方法实现的,但是这个方法有个问题,就是对数组的支持不全 ...

  2. 【jQuery基础学习】10 简单了解jQuery Mobile及jQuery各个级别版本的变化

    关于 jQuery Mobile jQuery Mobile是为了填补jQuery在移动设备应用上的一个新项目.它应用了HTML5和CSS3. 主要特性 基于jQuery构建. 采用与jQuery一致 ...

  3. Vue列表过渡

    前面的话 本文将详细介绍Vue列表过渡 概述 前面分别介绍了单元素CSS过渡和JS过渡,以及多元素过渡.如何同时渲染整个列表呢?在这种情景中,需要使用<transition-group>组 ...

  4. 账号配置vue版本的扫码下单以及对店铺进行装修的步骤

    新版vue配置说明文档 管理员后台: 1.配置管理-店铺配置(子账号)-扫码点餐tab页-开启vue版 2.配置管理-店铺配置(主账号)-扫码点餐tab页-开通装修配置 商家后台: 1.主账号-门店设 ...

  5. Vue使用过渡类名实现动画和自定义前缀

    Vue使用过渡类名实现动画和自定义前缀 1.效果演示 2.相关代码 <!DOCTYPE html> <html lang="en"> <head> ...

  6. VUE:过渡&动画

    VUE:过渡&动画 vue动画的理解 1)操作css的 trasition 或 animation 2)vue会给目标元素添加/移除特定的class 3)过渡的相关类名 xxx-enter-a ...

  7. OpenSSL所有版本的变化,从1.1开始架构有所变化,生成的lib名称也有所不同了,以及对Qt的影响

    The complete explanation is that 1.0.x and 1.1.x do not have the same naming conventions for the gen ...

  8. 黑马vue---46、vue使用过渡类名实现动画

    黑马vue---46.vue使用过渡类名实现动画 一.总结 一句话总结: vue动画的过渡类名的时间点中没有设置样式的话就是默认的样式 使用 transition 元素,把 需要被动画控制的元素,包裹 ...

  9. <el-tag></el-tag>部分属性与vue版本的兼容问题

    [01]标签使用按钮样式<el-tag effect="dark" v-if="myhotelinfo.runstatus=='T'" type=&quo ...

随机推荐

  1. 程序猿的日常——Java中的集合列表

    列表对于日常开发来说实在是太常见了,以至于很多开发者习惯性的用到数组,就来一个ArrayList,根本不做过多的思考.其实列表里面还是有很多玩法的,有时候玩不好,搞出来bug还得定位半天.所以这里就再 ...

  2. mybatis的知识点

    mybatis核心配置文件的配置 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE conf ...

  3. python中顺序查找分析和实现

    顺序查找算法是一种很基本的查找算法,该算法的复杂度一般是最大是O(n),假如加上顺序查找,算法的复杂度 还要降一倍,为O(n/2). Python的代码实现如下所示: def sequential_s ...

  4. 一点解决版本冲突的应急思路、怎样在所有jar包文件中搜索冲突的方法?

    maven是一个很好的项目管理工具,你可以轻松的定义一个引用,从而达到使用别人写好的库的作用.且maven可以轻松地和jenkins配合,从而使打包部署变得更容易. 但是也因为这样,我们变得更傻瓜了, ...

  5. 分布式文件系统FastDFS详解

    上一篇文章<一次FastDFS并发问题的排查经历>介绍了一次生产排查并发问题的经历,可能有些人对FastDFS不是特别的了解,因此计划写几篇文章完整的介绍一下这个软件. 为什么要使用分布式 ...

  6. vmware一步步安装centos

    软件环境:vmware10.0破解版 centos版本:6.4 1.启动vmware,新建虚拟机,选择自定义安装 2,出现如下界面,保持默认,点击下一步 3.这个步骤要特别注意,选择“稍后安装”,我们 ...

  7. TurnipBit开发板DIY呼吸的吃豆人教程实例

    转载请以链接形式注明文章来源(MicroPythonQQ技术交流群:157816561,公众号:MicroPython玩家汇) 0x00前言 吃豆人是耳熟能详的可爱形象,如今我们的TurnipBit也 ...

  8. Hive安装与配置详解

    既然是详解,那么我们就不能只知道怎么安装hive了,下面从hive的基本说起,如果你了解了,那么请直接移步安装与配置 hive是什么 hive安装和配置 hive的测试 hive 这里简单说明一下,好 ...

  9. GO开发[二]:golang语言基础

    [TOC] 一.变量 1.声明变量 变量相当于是对一块数据存储空间的命名,程序可以通过定义一个变量来申请一块数据存储空间,之后可以通过引用变量名来使用这块存储空间. Go语言引入了关键字var,而类型 ...

  10. .NET Core单文件发布静态编译AOT CoreRT

    .NET Core单文件发布静态编译AOT CoreRT,将.NET Core应用打包成一个可执行文件并包含运行时. 支持Windows, MacOS and Linux x64 w/ RyuJIT ...