Omi v1.0.2发布正式支持传递javascript表达式


Posted in Javascript onMarch 21, 2017

写在前面

Omi框架可以通过在组件上声明 data-* 把属性传递给子节点。

Omi从设计之初,就是往标准的DOM标签的标准传递方式靠齐。比如:

  • 下划线自动转驼峰, data-page-index传到子组件就变成this.data.pageIndex
  • data-xx 传递到子节点全都变成字符串,如data-page-index="1"到子节点中this.data.pageIndex就是字符串"1"

这样会有什么局限性和问题?如:

  • 无法传递JSON
  • 无法传递number类型
  • 无法传递bool类型

那么支持传递javascript表达式就能解决这些痛点。

废话不多说,来看神器的冒号。

冒号标记

看下面例子:

import Hello from 'hello.js'
Omi.makeHTML('Hello', Hello);
class App extends Omi.Component {
 render() {
 return `
 <div>
 <Hello :data-user="{ name : 'Dntzhang', favorite : 'Omi' }" />
 </div>
 `
 }
}
Omi.render(new App(),"#container")

在data-user前面加上冒号即:data-user,就代表传递的是js 表达式,够方便吧。

然后在Hello组件内就可以直接使用。

class Hello extends Omi.Component {
 render() {
 return `
 <div>
 <h1>{{user.name}} love {{user.favorite}}.</h1>
 </div>
 `
 }
}

你也可以在hello组件内打印出 this.data.user 试试。

传递其他类型

上面的例子展示了传递JSON,其他类型也支持。比如:

<Hello :data-age="18" />
 <Hello :data-xxx="1+1*2/3" />
 <Hello :data-is-girl="false" />
 <Hello :data-array-test="[1,2,3]" />

复杂类型

最后给大家看个稍微一丁点复杂的案例:

class Hello extends Omi.Component {
 handleClick(evt){
 alert( this.data.arrayTest[0].name)
 }
 render() {
 return `
 <ul>
 {{#arrayTest}}
 <li onclick="handleClick">{{name}}</li>
 {{/arrayTest}}
 </ul>
 `;
 }
}
Omi.makeHTML('Hello', Hello);
class App extends Omi.Component {
 render() {
 return `
 <div>
 <Hello :data-array-test="[{name:'dntzhang'},{name:'omi'},{name:'AlloyTeam'}]" />
 </div>
 `;
 }
}
Omi.render(new App(),"#container");

当然,在子组件中,你也可以不使用 mustache.js模板引擎的语法去遍历,使用ES6+的姿势去遍历。

class Hello extends Omi.Component {
 render() {
 return `
 <ul>
 ${this.data.arrayTest.map(item =>
 `<li>${item.name}</li>`
 ).join('')}
 </ul>
 `;
 }
}

这也是为什么omi提供了两个版本,omi.js和omi.lite.js的原因。omi.lite.js不包含mustache.js模板引擎。

以上所述是小编给大家介绍的Omi v1.0.2发布正式支持传递javascript表达式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
学习YUI.Ext 第二天
Mar 10 Javascript
JS Range HTML文档/文字内容选中、库及应用介绍
May 12 Javascript
jQuery Tools tooltip使用说明
Jul 14 Javascript
jquery struts 验证唯一标识(公用方法)
Mar 27 Javascript
jquery中获取元素里某一特定子元素的代码
Dec 02 Javascript
JavaScript实现带箭头标识的多级下拉菜单效果
Aug 27 Javascript
在 Express 中使用模板引擎
Dec 10 Javascript
Jquery EasyUI Datagrid右键菜单实现方法
Dec 30 Javascript
Angular 2父子组件数据传递之@Input和@Output详解 (上)
Jul 05 Javascript
浅谈Webpack 是如何加载模块的
May 24 Javascript
微信小程序事件 bindtap bindinput代码实例
Aug 26 Javascript
vue 实现弹窗关闭后刷新效果
Apr 08 Vue.js
jQuery插件HighCharts绘制简单2D柱状图效果示例【附demo源码】
Mar 21 #jQuery
jQuery插件HighCharts绘制简单2D折线图效果示例【附demo源码】
Mar 21 #jQuery
jQuery插件HighCharts绘制2D饼图效果示例【附demo源码下载】
Mar 21 #jQuery
80%应聘者都不及格的JS面试题
Mar 21 #Javascript
使用jQuery监听扫码枪输入并禁止手动输入的实现方法(推荐)
Mar 21 #jQuery
JavaScript中的普通函数和箭头函数的区别和用法详解
Mar 21 #Javascript
JavaScript 中 apply 、call 的详解
Mar 21 #Javascript
You might like
AMFPHP php远程调用(RPC, Remote Procedure Call)工具 快速入门教程
2010/05/10 PHP
实测在class的function中include的文件中非php的global全局环境
2013/07/15 PHP
set_exception_handler函数在ThinkPHP中的用法
2014/10/31 PHP
smarty中常用方法实例总结
2015/08/07 PHP
跟着JQuery API学Jquery 之三 筛选
2010/04/09 Javascript
JavaScript初学者应注意的七个细节小结
2012/01/30 Javascript
JavaScript快速检测浏览器对CSS3特性的支持情况
2012/09/26 Javascript
AngularJS iframe跨域打开内容时报错误的解决办法
2015/01/26 Javascript
jQueryMobile之Helloworld与页面切换的方法
2015/02/04 Javascript
jquery中val()方法是从最后一个选项往前读取的
2015/09/06 Javascript
JQuery手速测试小游戏实现思路详解
2016/09/20 Javascript
AngularJS中的按需加载ocLazyLoad示例
2017/01/11 Javascript
JS实现获取图片大小和预览的方法完整实例【兼容IE和其它浏览器】
2017/04/24 Javascript
使用Bootstrap打造特色进度条效果
2017/05/02 Javascript
bootstrap时间插件daterangepicker使用详解
2017/10/19 Javascript
Nuxt升级2.0.0时出现的问题(小结)
2018/10/08 Javascript
详解Vue的mixin策略
2020/11/19 Vue.js
[03:02]2014DOTA2西雅图邀请赛 让队员自己告诉你DK NAVI备战情况
2014/07/08 DOTA
python开发简易版在线音乐播放器
2017/03/03 Python
使用Python获取网段IP个数以及地址清单的方法
2018/11/01 Python
在python里面运用多继承方法详解
2019/07/01 Python
pandas DataFrame行或列的删除方法的实现示例
2019/08/02 Python
pytorch获取vgg16-feature层输出的例子
2019/08/20 Python
Python 实现黑客帝国中的字符雨的示例代码
2020/02/20 Python
Django框架静态文件处理、中间件、上传文件操作实例详解
2020/02/29 Python
PyCharm 在Windows的有用快捷键详解
2020/04/07 Python
Python常见反爬虫机制解决方案
2020/06/01 Python
Python读取多列数据以及用matplotlib制作图表方法实例
2020/09/23 Python
scrapy结合selenium解析动态页面的实现
2020/09/28 Python
python 获取字典键值对的实现
2020/11/12 Python
css3制作动态进度条以及附加jQuery百分比数字显示
2012/12/13 HTML / CSS
领导干部考察材料
2014/02/08 职场文书
办理房产过户的委托书
2014/09/14 职场文书
质监局领导班子对照检查材料思想汇报
2014/09/27 职场文书
python使用openpyxl库读写Excel表格的方法(增删改查操作)
2021/05/02 Python
详细聊聊vue中组件的props属性
2021/11/02 Vue.js