您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

Vue.js中的组件与模板探讨

2024/3/8 14:26:19发布24次查看
摘要:
指令是vue.js中一个重要的特性, 主要提供了一种机制将数据的变化映射为dom行为。 那什么交数据的变化映射为dom行为, vue.js是通过数据驱动的, 所以我们不会直接去修改dom结构, 不会出现类似$('ul').append('25edfb22a4f469ecb59f1190150159c6onebed06894275b65c1ab86501b08a632eb')这样的操作, 当数据变化时,指令会一句设定好的操作对dom进行修改, 这样就可以只关注数据的变化, 而不用去管理dom的变化和状态,
vue的内置指令
1. v-bind
v-bind主要用于绑定dom元素属性(attribute),
即元素属性实际的值是有vm实例中的data属性提供的。
例如:
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>vue的指令</title> <script src="../vue.js"></script> </head> <body> <!-- html模版 --> <p id="demo"> <span v-bind:cutomid="id">{{message}}</span> </p> <script> //数据 let obj ={ message:"hello world", id:'123' }; //声明式渲染 var vm = new vue({ el:'#demo', data:obj }); </script> </body> </html>
v-bind可以简写为“:”,
上述例子可以简写为<span :cotomid="id">
实现效果如下:
2. v-on
绑定事件监听器,简写为@。
昨天我们也用过,我们简写一下看一下效果
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>vue的指令</title> <script src="../vue.js"></script> </head> <body> <!-- html模版 --> <p id="demo"> <span @click="clickhandle">{{message}}</span> </p> <script> //数据 let obj = { message:"hello vue" }; //声明式渲染 var vm = new vue({ el:"#demo", data:obj, methods:{ clickhandle(){ alert("click") } } }); </script> </body> </html>
效果如下:
3.v-html
v-html,参数类型为string,
作用为更新innerhtml,
接受的字符串不会进行编译等操作,
按普通html处理
代码如下
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>vue的指令</title> <script src="../vue.js"></script> </head> <body> <!-- html模版 --> <p id="demo" v-html="html"></p> <script> //数据 let obj = { html:"<p>hello world</p>" }; var vm = new vue({ el:"#demo", data:obj }) </script> </body> </html>
实现效果如下
更多内置指令请查询官网:vue.js指令
模板
html模板
基于dom的模板,模板都是可解析有效的html
插值
文本:使用“mustache”语法(双大括号){{value}}
作用:替换实例上的属性值,
当值改变时,插值内容就会自动更新
原生的html:双大括号输出的是文本,不会解析html
属性:使用v-bind进行绑定,可以响应变化
使用javascript表达式:可以写简单的表达式
字符串模板
template字符串
template选项对象的属性
模板将会替换挂在元素。挂在元素的内容都将被忽略。
代码如下
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>template模板</title> <script src="../vue.js"></script> </head> <body> <!--html模板--> <p id="demo"></p> <script> //数据 let obj = { html:"<p>string</p>", abc:1 }; var str = "<p>hello</p>"; var vm = new vue({ el:"#demo", data:obj, template:str }) </script> </body> </html>
有木有发现什么惊奇的变化
根节点只能有一个
将html结构写在一对script标签中,设置type="x-template"
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>template模板</title> <script src="../vue.js"></script> </head> <body> <!--html模板--> <p id="demo"> <span>vue</span> </p> <script type="x-template" id="temp"> <p> hello,{{abc}}, <span>sunday</span> </p> </script> <script> //数据 let obj = { html:"<p>string</p>", abc:1 }; var vm = new vue({ el:"#demo", data:obj, template:"#temp" }); </script> </body> </html>
实现效果如下:
写在script标签中,还是比较局限,
如果别的文件也是这个结构的时候,
这个就不能重复使用。
模板render函数
render函数
render 选项对象的属性
createelement(标签名,{数据对象},[子元素]);
子元素为文本或者数组
我们还是来一段代码演示
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>render函数</title> <script src="../vue.js"></script> <style type="text/css"> .bg{ background: #ee0000; } </style> </head> <body> <p id="demo"></p> <script> //数据 let obj = { }; var vm = new vue({ el:"#demo", data:obj, render(createelement){ return createelement( //元素名 "ul", //数据对象 { class:{ bg:true } }, //子元素 [ createelement("li",1), createelement("li",2), createelement("li",3) ] ); } }) </script> </body> </html>
实现效果如下
总结
以上就是vue.js中的组件与模板探讨的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product