美文网首页
说说 Vue.js 实例及数据绑定能力

说说 Vue.js 实例及数据绑定能力

作者: deniro | 来源:发表于2018-09-23 17:46 被阅读191次

    1 创建实例

    通过 Vue() 构造函数就可以创建一个 Vue 的根实例:

    var app = new Vue({
      ...
    });
    

    1.1 el 选项

    el 选项用于绑定页面中的某个 DOM 元素。它可以是 HTMLElement 或是 CSS 选择器。

    在上例中:

    • HTMLElement 方式为 document.getElementById('app')
    • CSS 选择器方式为 #app

    建议使用 CSS 选择器方式,因为它更简洁。

    可以通过 app.$el 来访问这个 DOM 元素。

    1.2 data 选项

    data 选项用于设定需要双向绑定的数据。建议把所有会用到的数据都放在 data 选项,这样做便于维护。

    通过 Vue 实例,我们可以U获取 data 对象中的所有属性对象:

    html:

    <div id="app"></div>
    

    js:

    var app = new Vue({
        el: '#app',
        data: {
            content: '今天天气不错'
        }
    });
    console.log("content:" + app.content);//今天天气不错
    

    我们也可以在 data 选项中指向一个已定义的变量,这样它们之间就建立了双向绑定关系,即修改其中一个值时,另一个的值也会发生变化:

    var news = {
        title: '火车票购票新规:换乘购票需间隔40分钟以上'
    };
    var app3 = new Vue({
        el: '#app',
        data: news
    });
    console.log('app3.title:' + app3.title);//火车票购票新规:换乘购票需间隔40分钟以上
    
    //修改 Vue 实例属性
    app3.title = '菜鸟驿站数据被盗';
    console.log('news.title:' + news.title);//菜鸟驿站数据被盗
    
    //修改变量属性
    news.title = '央视中秋晚会节目单公布 吉隆坡悉尼海外分会场成亮点';
    console.log('app3.title:' + app3.title);//央视中秋晚会节目单公布 吉隆坡悉尼海外分会场成亮点
    

    2 生命周期

    创建实例时,会经历一系列的初始化过程,同时也会调用相应的生命周期中的钩子。我们可以在合适的时机,在这些钩子中执行某些特定的业务。

    常用的生命周期钩子有这些:

    钩子 说明
    created 实例化创建完成后调用,此阶段完成了数据观测,但尚未挂载, $el 还不可用,一般在此进行一些数据初始化处理工作。
    mounted el 挂载到实例后调用,一般在此编写第一个业务逻辑 。
    beforeDestroy 实例被销毁之前调用 。 一般在此解绑通过 addEventListener 添加的监听事件。

    注意:钩子中的 this 指向它自身的 Vue 实例。

    var app4 = new Vue({
        el: '#app',
        data: {
            name:'deniro'
        },
        created:function () {
            console.log(this.name);//deniro
        },
        mounted:function () {
            console.log(this.$el);//<div id="app"></div>
    
        }
    });
    

    3 插值与表达式

    插值语法是双大括号( Mustache 语法) “{{ }}”,它会自动将我们双向绑定的数据实时显示出来。

    html:

    <div id="app">
        {{friend}}
    </div>
    

    js:

    var app = new Vue({
        el: '#app',
        data: {
            friend: 'Jack'
        }
    })
    

    双大括号 {{friend}} 会被替换为 Jack。

    只要数据被修改,那么文本插值中的内容都会被替换。我们做一个计数器,它的值每秒会递增 1:

    html:

    <div id="app2">
        {{count}}
    </div>
    

    js:

    var app2 = new Vue({
        el: '#app2',
        data: {
            count: 1
        },
        mounted: function () {
            var that = this;//设置 that 为当前 Vue 实例
    
            //每秒递增计数器
            this.timer = setInterval(function () {
                that.count++;//递增
            }, 1000);
        },
        beforeDestroy: function () {//销毁前,清除定时器
            if (this.timer) {
                clearInterval(this.timer);
            }
        }
    });
    

    效果:

    插值表达式还支持使用 JavaScript 表达式进行简单的运算 、 甚至支持三元运算符。

    html:

    <div id="app5">
        {{num*3}}
        {{isTrue?'真的':'假的'}}
        {{context.length}}
    </div>
    

    js:

    var app5 = new Vue({
        el: '#app5',
        data: {
            num: 3,
            isTrue: true,
            context: '听轻音乐是一种享受O(∩_∩)O~'
        }
    });
    

    输出结果:

    9 真的 17

    注意: Vue 只支持单个表达式,不支持语句和流程控制 。 另外,在表达式中,不能使用用户自定义的全局变量,只能使用 Vue 内部定义全局变量,如 Math 和 Date 等。

    4 输出 HTML 代码

    可以使用 v-html 属性,让某个 HTML 元素内包裹 HTML 代码:

    html:

    <div id="app3">
        <span v-html="h1"></span>
    </div>
    

    js:

    var app3 = new Vue({
        el: '#app3',
        data: {
            h1: '<h1>据说用牙刷刷猫时,猫会感觉像被妈妈舔一样,网友试了下结果……</h1>'
        }
    });
    

    注意:用户输入的内容,如果直接使用 v-html 属性输出 HTML 代码,那么就有可能遭遇 XSS 攻击的问题,所以服务端必须对用户提交的内容进行过滤处理(如转义尖括号 <>)。

    5 v-pre 属性

    可以使用 v-pre 属性,来跳过这个元素与其子元素的编译过程,比如希望显示 {{}} 字符串:

    html:

    <div id="app4">
        <span v-pre>{{content}}</span>
    </div>
    

    6 过滤器

    Vue.js 支持在 {{ }} 插值的尾部 · 添加一个管道符 “ | ” 实现数据过滤功能,这项能力经常用于格式化文本,比如字母全部大写,格式化货币数值等 。 过滤的规则是自定义的,通过给 Vue 实例添加选项 filter 来设置,假设我们对返回的字符串,设置为全部大写:

    html:

    <div id="app6">
        {{str | upperCaseStr}}
    </div>
    

    js:

    var app6 = new Vue({
        el: '#app6',
        data: {
            str: "deniro"
        },
        filters: {
            upperCaseStr: function (val) {
                return val.toUpperCase();
            }
        }
    });
    

    输出结果:

    DENIRO

    注意:过滤选项名是 filters,有 s 结尾的哦O(∩_∩)O~

    过滤器还可以串联起来:

    {{ val | filterFuntionA | filterFuntionB | ... }}

    因为过滤器是 JavaScript 函数,所以可以定义入参:

    {{ val | filterFuntion(arg1,arg2,...)}}

    注意:入参是从过滤函数的第二个参数开始的,因为第一个是 val。


    过滤器适用于处理简单的文本格式化操作,如果需要处理更为复杂的数据转换操作,建议使用计算属性。

    相关文章

      网友评论

          本文标题:说说 Vue.js 实例及数据绑定能力

          本文链接:https://www.haomeiwen.com/subject/gixqoftx.html