Vue模板语法插值Attribute(v-bind指令)HTML标签属性(attribute)的值

Vue / 1281人浏览 / 0人评论

Mustache 语法不能作用在 HTML attribute 上,遇到这种情况应该使用 v-bind 指令:

Vue.js 是什么?

Vue是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue 也完全能够为复杂的单页应用提供驱动。

如果你已经是有经验的前端开发者,想知道 Vue 与其它库/框架有哪些区别,请查看对比其它框架。

Vue模板语法插值Attribute(v-bind指令)HTML标签属性(attribute)的值,动态绑定

以下代码是保存至一个index.html的文档(文件后缀名是.html)中,并非是.vue的文件,当今后学会了一些更vue复杂的应用的时候,比如CLI创建了更复杂的vue应用,并支持单文件组件,那在项目下创建的文件可能就是以.vue为后缀的文件。

Mustache 语法不能作用在 HTML attribute 上,遇到这种情况应该使用 v-bind 指令:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Vue模板语法Attribute(v-bind指令)HTML标签属性(attribute)的值,动态绑定</title>
    <script src="vue.js" type="text/javascript" charset="utf-8"></script>    
</head>
<body>
    <div id="app">
        <span>{{ sitename }}</span>
        <!--Mustache 语法不能作用在 HTML attribute 上,遇到这种情况应该使用 v-bind 指令:-->
        <!--给p标签动态添加个class(p标签属性),其p标签class属性值为vue对象中data下class_name的值。-->
        <p v-bind:class="dynamicclass">{{ message }}</p>
        <p v-bind:id="dynamicid">{{ message }}</p>
        <!--对于布尔 attribute (它们只要存在就意味着值为 true),v-bind 工作起来略有不同,在这个例子中:-->
        <button v-bind:disabled="isButtonDisabled">Button</button>
        <!--
            如果 isButtonDisabled 的值是 0、null、undefined 或 false,则 disabled attribute 甚至不会被包含在渲染出来的 <button> 元素中。
            反之如果是 true、不等于0的值、空或者非空字符串,则 disabled attribute 会被包含在渲染出来的 <button> 元素中。            
        -->
    </div>
    <script type="text/javascript">
        var vm = new Vue({
            el: '#app',
            data: {
                message: 'Hello Vue!',
                sitename: '编程之吧',
                dynamicclass: 'show',
                dynamicid: 'show',
                isButtonDisabled: true,
            }
        });
    </script>
    <style>
        #show, .show{
            color:red;
            font-size:20px;
        }
    </style>
</body>
</html>

转载注明:

0 条评论

还没有人发表评论

发表评论 取消回复

记住我的信息,方便下次评论
有人回复时邮件通知我