ch3-模板语法({{}} v-html v-bind:id 表达式 指令 修饰符 过滤器)
1 模板语法
Vue.js 使用了基于 HTML 的模版语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据。
所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循规范的浏览器和 HTML 解析器解析。 在底层的实现上, Vue 将模板编译成虚拟 DOM 渲染函数。结合响应系统,在应用状态改变时,
Vue 能够智能地计算出重新渲染组件的最小代价并应用到 DOM 操作上。 如果你熟悉虚拟 DOM 并且偏爱 JavaScript 的原始力量,你也可以不用模板,
直接写渲染(render)函数,使用可选的 JSX 语法(语法糖写的xml语法通过jsx转换工具变成js代码)。 2 插值
2.1 插入文本
2.1.1 数据绑定的常用形式: 使用'Mustache'语法({{}})双大括号 插入文本数据
<div id="test1">{{str}}</div> <script>
var app1 = new Vue({
el: '#test1',
data: {
str: '你好'
}
})
</script>
//console修改数据
app1.str = '123' // 内容随着改变
2.1.2 v-once指令也可以执行 一次性 的插值,当数据改变的时候,内容不会更新
<div id="test1">
{{str}}
<p v-once>{{str}}</p>
</div> //console修改数据
app1.str = '123'; //v-once标签外部{{}}绑定的发生内容变化 v-once节点里面的不会变化
2.2 插入纯html
2.2.1 输出html使用 v-html
<div id="test2" v-html="html">
<p>{{html}}</p>
</div> let app2 = new Vue({
el: '#test2',
data: {
html: '<h2><span>你好</span><h2>'
}
});
2.2.2 被插入的内容都会被当做 HTML —— 数据绑定会被忽略。
注意,你不能使用 v-html 来复合局部模板,因为 Vue 不是基于字符串的模板引擎。
组件更适合担任 UI 重用与复合的基本单元。 2.2.3 你的站点上动态渲染的任意 HTML 可能会非常危险,因为它很容易导致 XSS 攻击。
请只对可信内容使用 HTML 插值,绝不要对用户提供的内容插值。
2.3 插入属性
2.3.1 Mustache({{}}) 不能在 HTML 属性中使用,应使用 v-bind 指令
<style>
#sub{
color:red;
}
</style> <div id="test3">
<div :id="sub">123</div> // :相当于v-bind,这是它的简写
</div>
let app3 = new Vue({
el: '#test3',
data: {
sub: 'sub'
}
});
2.3.2 这对布尔值的属性也有效 —— 如果条件被求值为 false 的话该属性会被移除:
<div id="test4">
<button :disabled="canopt">按钮</button>
</div>
let app4 = new Vue({
el: '#test4',
data: {
canopt: true
}
})
<div id="test4">
<button :disabled="canopt">按钮</button>
</div>
let app4 = new Vue({
el: '#test4',
data: {
canopt: false
}
})
2.4 使用js表达式
2.4.1 常见用法
<div id="test5">
{{number+1}} <br>
{{ok?'yes':'no'}} <br>
{{str.split('').reverse().join('')}} <br>
<div :id="'list-'+id">son</div>
</div> let app5 = new Vue({
el: '#test5',
data: {
number: 1,
ok: true,
str: 'hello Vuejs',
id: 'son'
}
});
3 指令
3.1 参数 一些指令能接受一个“参数”,在指令后以冒号指明。
3.1.1 例如, v-bind 指令被用来响应地更新 HTML 属性:
<a id="test6" :href="url">
百度一下
</a> let app6 = new Vue({
el: '#test6',
data: {
url: 'http://www.baidu.com'
}
})
在这里 href 是参数,告知 v-bind 指令将该元素的 href 属性与表达式 url 的值绑定。
3.1.2 v-on 指令,它用于监听 DOM 事件 参数是监听的事件名
<div id="test7">
<button @click="clickMe">点击</button> //@ v-on:的简写
</div>
let app7 = new Vue({
el: '#test7',
methods: {
clickMe: function () {
alert('hello world Vuejs');
}
}
});
3.2 修饰符(Modifiers)是以半角句号 . 指明的特殊后缀,用于指出一个指令应该以特殊方式绑定。
2.6.1 .prevent 修饰符告诉 v-on 指令对于触发的事件调用 event.preventDefault():
<div id="test8">
<form action="/xxx" method="get" @submit.prevent="onSubmit">
<button type="submit">提交</button>
</form>
</div>
let app8 = new Vue({
el: '#test8',
});
4 过滤器
Vue.js 允许你自定义过滤器,可被用作一些常见的文本格式化。
过滤器可以用在两个地方:mustache({{}}) 插值和 v-bind 表达式。
<div id="test9">
{{str | firstUpper | lastUpper}} <br>
<div :id="str | uppercase">33</div>
{{str | uppercase}} <br>
{{str | isUppercase(false)}}
</div> let app9 = new Vue({
'el': '#test9',
data: {
str: 'jesonhu'
},
filters: {
firstUpper: function (value) { //自定义首字母大写函数
if(!value) return ''; //value不存在返回''
value = value.toString();
return value.charAt(0).toUpperCase()+value.slice(1);
//value.charAt(0).toUpperCase() 取得value字符串索引为0的字符并大写
//value.slice(1) 除首位之后该字符串剩下的部分
},
lastUpper: function (value) { //自定义末尾字母大写函数
if(!value) return ''; //value不存在返回''
value = value.toString();
let len = value.length;
return value.slice(0,(len-1)) + value.charAt(len-1).toUpperCase();
},
uppercase: function (value) { //自定义字符大写函数
if(!value) return ''; //value不存在返回''
value = value.toString();
let newStr = '';
for(let i=0;i<value.length;i++){
newStr += value.charAt(i).toUpperCase();
}
value = newStr;
return value;
},
isUppercase: function (value, bool) { //自定义是否字符大写函数
//默认第一个参数为筛选器的值 筛选器传递的第一个实参会作为过滤方法的第二个形参,以此对应
if(!value) return ''; //value不存在返回''
value = value.toString();
let newStr = '';
if(bool){
for(let i=0;i<value.length;i++){
newStr += value.charAt(i).toUpperCase();
}
value = newStr;
}
return value;
}
}
})
ch3-模板语法({{}} v-html v-bind:id 表达式 指令 修饰符 过滤器)的更多相关文章
- 前端MVC Vue2学习总结(三)——模板语法、过滤器、计算属性、观察者、Class 与 Style 绑定
Vue.js 使用了基于 HTML 的模版语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据.所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循规范的浏览器和 HTML 解 ...
- vue基础——模板语法
模板语法介绍 Vue.js使用了基于HTML的模板语法,允许开发者声明式地将dom绑定至底层Vue实例的数据.所有Vue.js的模板都是合法的HTML,所以能被遵循规范的浏览器和HTML解析器解析. ...
- vue基础---模板语法
Vue.js 使用了基于 HTML 的模板语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据.所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循规范的浏览器和 HTML 解 ...
- vue入门:(模板语法与指令)
vuejs使用及HTML的模板语法,可以实现声明式将DOM绑定至底层VUE实例的数据.通过模板语法将数据渲染进DOM的系统,结合响应系统,在应用状态改变时,Vue能够计算出重新渲染组件的最小代价并应用 ...
- 【每天半小时学框架】——React.js的模板语法与组件概念
[重点提前说:组件化与虚拟DOM是React.js的核心理念!] 先抛出一个论题:在React.js中,JSX语法提倡将 HTML 和 CSS 全都写入到JavaScrip ...
- Django学习笔记(3)——表单,测试和模板语法的学习
一,表单form 为了接收用户的投票选择,我们需要在前段页面显示一个投票界面,让我们重写之前的polls/detail.html文件,代码如下: <h1>{{ question.quest ...
- Django(四)框架之第三篇模板语法
https://www.cnblogs.com/yuanchenqi/articles/6083427.htm https://www.cnblogs.com/haiyan123/p/7725568. ...
- Django框架之第三篇模板语法(重要!!!)
一.什么是模板? 只要是在html里面有模板语法就不是html文件了,这样的文件就叫做模板. 二.模板语法分类 一.模板语法之变量:语法为 {{ }}: 在 Django 模板中遍历复杂数据结构的关键 ...
- Django之模板语法
Django框架之第三篇模板语法(重要!!!) 一.什么是模板? 只要是在html里面有模板语法就不是html文件了,这样的文件就叫做模板. 二.模板语法分类 一.模板语法之变量:语法为 {{ }}: ...
随机推荐
- 关于破解Quartus
在网上找了很多资料,说的也很详细,安装的Quartus13.0,在破解的时候遇到x64和x86两种破解器,两个针对的路径不一样,如果搞混了~可能就会出现这种情况 Error: Current li ...
- jQuery常用工具方法
前面的话 jQuery提供一些与元素无关的工具方法,不必选中元素,就可以直接使用这些方法.如果理解原生javascript的继承原理,那么就能理解工具方法的实质.它是定义在jQuery构造函数上的方法 ...
- 转深入Java虚拟机 之四:类加载机制
转载请注明出处:http://blog.csdn.net/ns_code/article/details/17881581 类加载过程 类从被加载到虚拟机内存中开始,到卸载出内存为止,它的整个 ...
- 【集美大学1411_助教博客】团队作业7——Alpha冲刺之事后诸葛亮
写在前面的话 alpha阶段都顺利完成了,大家这次作业完成得都很认真.我觉得通过这些问题,大家既可以回顾自己的alpha阶段,又可以给beta阶段做一些指引.但看了所有组的博客,没有一个组在这些问题之 ...
- 第二次项目冲刺(Beta阶段)--第五天
一.站立式会议照片 二.项目燃尽图 三.项目进展 - 今天任务是改进程序使程序能完成docx文件的读取,但是并没有成功实现解决该问题,所以燃尽图没有前进. -遇到的问题:不支持docx最早认为是jar ...
- 团队作业4---第一次项目冲刺(ALpha)版本 第五天
一.Daily Scrum Meeting照片 二.燃尽图 三.项目进展 a.完成所有基础功能 b.正在进行测试调试 四.困难与问题 1.根据测试需求功能,部分基础功能不能实现,性能不达标,后续已完成 ...
- 201521123081《Java程序设计》 第6周学习总结
1. 本周学习总结 1.1 面向对象学习暂告一段落,请使用思维导图,以封装.继承.多态为核心概念画一张思维导图,对面向对象思想进行一个总结. 注1:关键词与内容不求多,但概念之间的联系要清晰,内容覆盖 ...
- 201521123030 《Java程序设计》 第10周学习总结
1. 本周学习总结 2. 书面作业 本次PTA作业题集异常.多线程 1.finally 题目4-2 1.1 截图你的提交结果(出现学号) 1.2 4-2中finally中捕获异常需要注意什么? 在fi ...
- JS中的DOM对象及JS对document对像的操作
DOM对象 windows:属性:opener(打开者) 方法:open().close(),setTimeout().setInterval()... location:属性:href 方法:rel ...
- 在linux下通过hexdump生成一个十六进制的文本保存文件,解析此文件转变成正常源代码文件。
举例说明: 此十六进制保存的文件为此源代码hexdump生成的: #include<stdio.h> #include<string.h> #include<stdlib ...