vue.js 实用版(一)

Vue.js基本概念

首先通过将vue.js作为一个js库来使用,来学习vue的一些基本概念,我们下载了vue.js后,需要在页面上通过script标签引入vue.js,开发中可以使用开发版本vue.js,产品上线要换成vue.min.js。


Vue实例

每个 Vue 应用都是通过实例化一个新的 Vue对象开始的:

window.onload = function(){
    var vm = new Vue({
        el:'#app',
        data:{message:'hello world!'}
    });
}    
......

{{ message }}

其中,el属性对应一个标签,当vue对象创建后,这个标签内的区域就被vue对象接管,在这个区域内就可以使用vue对象中定义的属性和方法。

数据与方法

当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其data对象中能找到的所有的属性。当这些属性的值发生改变时,视图将会产生“响应”,即匹配更新为新的值。还可以在Vue实例中定义方法,通过方法来改变实例中data对象中的数据,数据改变了,视图中的数据也改变。

window.onload = function(){
    var vm = new Vue({
        el:'#app',
        data:{message:'hello world!'},
        methods:{
            fnChangeMsg:function(){
                this.message = 'hello Vue.js!';
            }
        }
    });
}    
......

{{ message }}

Vue.js模板语法

模板语法指的是如何将数据放入html中,Vue.js使用了基于 HTML的模板语法,允许开发者声明式地将DOM绑定至底层 Vue 实例的数据。所有 Vue.js的模板都是合法的 HTML ,所以能被遵循规范的浏览器和 HTML 解析器解析。

插入值

数据绑定最常见的形式就是使用“Mustache”语法 (双大括号) 的文本插值:

Message: {{ msg }}

如果是标签的属性要使用值,就不能使用“Mustache”语法,需要写成使用v-bind指令:

百度网

插入的值当中还可以写表达式:

{{ number + 1 }}
{{ ok ? 'YES' : 'NO' }}
{{ message.split('').reverse().join('') }}
链接文字

指令

指令 (Directives) 是带有“v-”前缀的特殊属性。指令属性的值预期是单个JavaScript表达式,指令的职责是,当表达式的值改变时,将其产生的连带影响,响应式地作用于DOM。常见的指令有v-bind、v-if、v-on。


是否显示这一段

缩写

v-bind和v-on事件这两个指令会经常用,所以有简写方式:


...


...






Class绑定

使用v-bind指令来设置元素的class属性,它们的属性值可以是表达式,vue.js在这一块做了增强,表达式结果除了是字符串之外,还可以是对象或者数组。

Class绑定

对象语法

可以给v-bind:class传一个对象,以动态的切换class

data属性值如下:

data: {
  isActive: true,
  hasError: false
}

最终渲染的效果:

也可以给v-bind:class传一个对象引用

data属性值可以写成:

data: {
  classObject: {
    active: true,
    'text-danger': false
  }
}

数组语法

可以给v-bind:class传一个数组,以应用一个 class 列表

...... data: { activeClass: 'active', errorClass: 'text-danger' }

最终渲染为:

如果你也想根据条件切换列表中的 class,可以用三元表达式:


你可能感兴趣的:(web,html,css,jquery,vue.js)