到了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. css div 细边框

    .item{ max-width:48%; float:left; padding:2px; border-top:1px solid #000; border-left:1px solid #000 ...

  2. MyEclipse 2015利用Cygwin+CDT搭建C/C++开发环境

    GitHub原文:https://github.com/x113773/testall/issues/22 首先安装Cygwin 1:首先去网站 www.cygwin.com 下载 Cygwin 的 ...

  3. svn conflict 冲突解决

    1. 同一处修改文件冲突 开发人员都知道代码管理工具是开发中一个必不可少的工具,这里也不废话详细介绍了.不管你个人喜欢git还是svn还是其他,但还有一大部分公司在使用svn做代码管理工具.这里详细介 ...

  4. linux下一键安装redis并设置为后台进程及开机启动

    1.下载适合你的版本的redis(下载页面https://redis.io/download),我下载的是4.0.6版本 wget http://download.redis.io/releases/ ...

  5. windows PAE扩展和AWE编程

    在32位windows上只能看到最大3GB的内存空间,而且每个应用程序只能访问4GB的的内存,这个限制是windows独有的,为了使程序能够访问大于4GB的内存空间,需要使用AWE编程接口,同时需要开 ...

  6. flush table with read lock的轻量级解决方案[原创]

    为什么要使用FTWRL   MySQL dba在日常工作中,数据备份绝对是工作频度最高的工作内容之一.当你使用逻辑方式进行备份(mydumper,mysqldump)或物理方式进行备份(percona ...

  7. 简易安卓APP

    简介 现在来分享期末做的安卓大作业--生活百科. 本项目只是单纯的一个大作业,没有考虑实际的需求,所以有设计不合理的地方,请见谅. 这个项目有三大功能(因为是使用了侧边栏所以是可以继续往里面添加功能的 ...

  8. 工作整理: python报表系统常见错误整理

    1.一般收不到邮件是因为配置文件邮箱写错 2.如果报表数据不对,看数据插入的时候是否再次写入产生冲突 3.如果收不到报表某些组别的excel查看组别名称是否匹配正确,是否匹配成功,不成功无法发送

  9. Java眼中的XML--------文件读取

     XML 的初次邂逅 初次邂逅XML 如何进行XML文件解析前的准备工作 在Java程序中如何获取xml文件的内容 在Java程序中读取xml文件的过程也成为----解析xml文件 解析的目的:获取节 ...

  10. Fiddler抓取https证书问题

    正常的使用方法  Fiddler 抓包工具总结    大部分问题的解决方案  fiddler4在win7抓取https的配置整理 像我脸一样黑的解决方案  Fiddler https 证书问题     ...