vue过渡(动画)

  本质走的css3: transtion ,animation

  <div id="div1" v-show="bSign" transition="fade"></div>

    动画:
.fade-transition{ }
进入:
.fade-enter{
opacity: 0;
}
离开:
.fade-leave{
opacity: 0;
transform: translateX(200px);
} 也可以使用animation.css动画库,并且vue实例还有一个transition配置项 <div class="animated" transition="bounce" v-show="bSign"></div> new Vue({
el:'',
data:{},
methods:{},
transitions:{
bounce:{
enterClass:'zoonInLeft',
leaveClass:'zoomOutRight'
}
} })

vue组件

  组件:一个大对象,定义一个组件

var Aaa=Vue.extend({
template:'<h3>我是标题3</h3>'
});

  注册组件:  

  1、全局组件,通过Vue的方法component注册到全局类Vue上

Vue.component('aaa',Aaa); //挂在全局Vue对象上的
//全局组件可以在以后的通过new出来的vue实例中使用 *组件里面放数据:
组件里面的data必须是函数的形式,函数必须返回一个对象(json数据)

    2、局部组件

    放到某个组件内部,通过components配置项,注册到(组件)实例中

var vm=new Vue({
el:'#box',
data:{
bSign:true
},
components:{ //局部组件 挂在vue实例内的
aaa:Aaa
}
});

  另一种定义注册方式.(推荐);上面是定义和注册分步进行,这种方式是定义和注册合为一步了

      全局:
Vue.component('my-aaa',{
template:'<strong>好</strong>'
}); 局部:
var vm=new Vue({
el:'#box',
components:{
'my-aaa':{
template:'<h2>标题2</h2>'
}
}
});

组件配合模板使用

  将组件中的模板字符串,抽出模板(多个标签)到html中

   1. template:'<h2 @click="change">标题2->{{msg}}</h2>'

    2. 单独放到某个地方
a). <script type="x-template" id="aaa">
<h2 @click="change">标题2->{{msg}}</h2>
</script> b). 推荐
       <template id="aaa">
<h1>标题1</h1>
<ul>
<li v-for="val in arr">
{{val}}
</li>
</ul>
</template>

  动态组件:(可以做选择卡)

<component :is="组件名称"></component>

 组件间通信

   vue默认情况下,子组件也没法访问父组件数据 

1. 子组件就想获取父组件data
a、在调用子组件:绑定属性
<bbb :m="数据"></bbb> b、子组件之内:通过props获取以上绑定的属性
props:['m','myMsg'] 也可以指定类型的props
props:{
'm':String,
'myMsg':Number
}
   c、之后就可以在子组件的methods里面或者html插值里面使用了
2. 父级获取子级数据
*子组件实例主动把自己的数据,发送到父级,父级通过v-on:自定义事件监听,捕获到发送的事件触发,并接收到数据 vm.$emit(事件名,数据); v-on: @事件名=“自己的方法”

    另外还有一种传值方法(2.0中已经废除):

      vm.$dispatch(事件名,数据) 子级向父级发送数据
      vm.$broadcast(事件名,数据) 父级向子级广播数据
      配合: event:{}

vue中的slot

  位置、插槽;作用就是占个位置

  就是在使用组件时,为组件里面的内容能留有渲染的位置
  多个slot可以是用name进行区分

  类似ng里面 transclude (指令)

vue路由

  vue--->单页面(SPA)应用,是根据不同的路由(url地址),展示不同的效果(组件)

  用到插件vue-router

html:
<a v-link="{path:'/home'}">主页</a> 跳转链接 展示内容:
<router-view></router-view>
js:
//1. 准备一个根组件
var App=Vue.extend(); //2. Home News组件都准备
var Home=Vue.extend({
template:'<h3>我是主页</h3>'
}); var News=Vue.extend({
template:'<h3>我是新闻</h3>'
}); //3. 准备路由
var router=new VueRouter(); //4. 关联(将组件名与定义的组件关联,之后就可以在html中通过v-link使用了)
router.map({
'home':{
component:Home
},
'news':{
component:News
}
}); //5. 启动路由
router.start(App,'#box');    跳转(路由重定向):
router.redirect({
‘/’:'/home'
});

  路由多层嵌套:在map关联的路由名称后的配置项subRoutes里进行配置次级路由

    主页    home
登录 home/login
注册 home/reg
新闻页 news subRoutes:{
'login':{
component:{
template:'<strong>我是登录信息</strong>'
}
},
'reg':{
component:{
template:'<strong>我是注册信息</strong>'
}
}
}  

    路由其他信息:可以通过路由后面的参数传递,并在当前路由组件的模板中使用
    /detail/:id/age/:age

    {{$route.params | json}} -> 当前参数

    {{$route.path}} -> 当前路径

    {{$route.query | json}} -> 查询字符串数据

vue-loader(.vue文件加载器)

    通过路由实现页面切换,项目实现单文件组件,即使用.vue文件,.vue文件的编译需要vue-loader处理

    其他loader->  css-loader、url-loader、html-loader、file-loader.....

    后台: nodeJs ->  require  exports

    browserify  模块加载,只能加载js

    webpack   模块加载器, 一切东西都是模块, 最后打包到一块了 (包括图片、css)

    require('style.css'); ->   css-loader、style-loader

    vue-loader基于webpack

.vue文件

  vue单文件组件,放置的是vue组件代码,结构包括三部分

     <template>
html
</template> <style>
css
</style> <script>
//js (平时代码、ES6) babel-loader(编译es6)
       export default{
        //里面像组件使用一样的
        data(){
          return {
            msg:'welcome Vue'
          }
        }
       }
</script>

3、vueJs基础知识03的更多相关文章

  1. vue面试题整理vuejs基础知识整理

    初级参考 1.v-show 与 v-if 区别 v-show 是css隐藏,v-if是直接销毁和创建,所以频繁切换的适合用v-show 2.计算属性和 watch 的区别 计算属性是自动监听依赖值的变 ...

  2. 6、vueJs基础知识06

    vue动画 transition 之前1.0版本是以 属性的形式展示的 <p transition="fade"></p> .fade-transition ...

  3. 1、vueJs基础知识01

    vue是框架,vue.js是vue框架的核心js库 库:是一个封装好的特定的方法的集合,提供给开发者使用,库没有控制权,控制权在使用者手中.代表:jQuery.underscore.util 框架:框 ...

  4. Android基础知识03—Activity的基本用法

    ------Activity 活动------ 活动 Activity 是一种包含用户界面的组件,即一个界面就是一个活动 创建活动的过程: >> 创建一个类,继承自Activity类,并且 ...

  5. 7、vueJs基础知识07

    UI组件库 element-ui和mint-ui 其实都是借鉴了bootstrap bootstrap: 由twitter 开源 简洁.大方 官网文档https://www.bootcss.com/ ...

  6. 5、vueJs基础知识05

    vue2.0相比于1.0的变化 1.在每个组件模板中,不再支持片段代码,需要一个根元素包裹 组件中模板: 之前: <template> <h3>我是组件</h3>& ...

  7. 4、vueJs基础知识04

    简单的目录结构: |-index.html |-main.js 入口文件 |-App.vue vue文件(组件),官方推荐命名法(首字母大写) |-components      组件存放的文件夹 | ...

  8. 2、vueJs基础知识02

    vue生命周期: 钩子函数: created -> 实例已经创建 √ beforeCompile -> 编译之前 compiled -> 编译之后 ready -> 插入到文档 ...

  9. python基础知识0-3

    一.根据用户输入内容输出其权限 # 根据用户输入内容打印其权限    # FYT --> 超级管理员 # eric --> 普通管理员 # tony,rain --> 业务主管 # ...

随机推荐

  1. OS UIButton之UIButtonType详解-转

    我做了一个关于UIButtonType的Demo,效果如下图: UIButtonType各个类型的解释: typedef NS_ENUM(NSInteger, UIButtonType) { UIBu ...

  2. ANE打包工具使用视频教程 -- 梦宇技术 @极客学院

    来源:http://xtiqin.blog.163.com/blog/static/17017217920133584934827/ ANE打包工具使用视频教程 2013-04-05 08:49:34 ...

  3. 经典数据结构与算法在经典软件(linux kernel)中的应用

    参考文章:Core Alorgithms deployed linux中的priority search tree数据结构研究 虚拟内存: 1.红黑树,管理与进程关联的vm_area_struct实例 ...

  4. HTTP协议复习二--代理

    代理(Proxy)是HTTP协议中请求方和应答方中间的一个环节,作为“中转站”,既可以转发客 户端的请求,也可以转发服务器的应答.代理有很多的种类,常见的有:1.匿名代理:完全“隐匿”了被代理的机器, ...

  5. [daily] ssh通过私钥导出公钥

    在使用key方式登录ssh服务的时候,我们知道ssh key是使用公钥ssh-keygen工具生成的. 有时候,我们只保存了私钥,但是并没有保存公钥.这个时候,可以使用如下方法,   从私钥中将公钥导 ...

  6. Microsoft Edge设置socks代理

    自已摸的,非官方: 直接修改注册表: REGEDIT4 [HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Internet Se ...

  7. 2013.5.3 - KDD第十五天

    今天上午把昨天的想法给中秋发过去了,然后我就开始科普随机森林: 随机森林是一种比较新的机器学习模型.经典的机器学习模型是神经网络,有半个多世纪的历史了.神经网络预测精确,但是计算量很大.上世纪八十年代 ...

  8. 2013.4.29 - KDD第十一天

    今天上午在图书馆写FIrst集,真心没写出来,算法是昨天找好的,不过实现的话还是需要很大的代码量,然后就打算用郑茂或者韩冰的代码了. 晚上图书馆快关门的时候开始思考KDD的问题, 我一开始打算给中秋发 ...

  9. python蟒蛇绘制的代码以及目前还不知道怎么用的RGB颜色对照表

    #PythonDraw.py import turtle#引入海龟库 turtle.setup(650,350,200,200)#确定窗口大小,长650,高350,确定窗口位置,距离电脑左上角200, ...

  10. Can you answer these queries? (线段树

    题目 题意: 初始给你n个数,通过m个操作,  操作0是使区间范围内的每一个a[i]都变成 根号a[i] ,操作1是查询区间范围内数字的和. 思路: 如果一个节点sum[rt]是1的话,根号1还是1, ...