riot.js 学习【一】自定义标签
Riot.js最强大的功能,莫过于自定义标签,先来一段代码,看个效果:
[code]<!Doctype html> <html> <head> <meta charset="utf-8" /> <script type="text/javascript" src="riot.js"></script> <script type="text/javascript" src="compiler.js"></script> </head> <body> <!-- 调用自定义标签 --> <timer start="10"></timer> </body> <!-- 最前面一定要有空格或TAB,留意它的type --> <script type="riot/tag"> <timer> <h3>Times: { index }</h3> this.index = opts.start || 0; var self = this; tick(){ // 每个1秒,index自增 this.index++; // 调用this.update更新UI【最欣赏这个了,能自己控制】 this.update(); } var timer = setInterval(this.tick, 1000); </timer> </script> <!-- 调用riot,启动自定义标签timer --> <script type="text/javascript"> riot.mount("timer"); </script> </html>
效果如下[每个1秒,times的值,就+1]:
说一下,新人会遇到的坑:
script type=”riot/tag”
compiler会遍历所有带有script type=”riot/tag” 的元素,如果script有src,则会加载外部的文件,如果没有src,则编译script里的内容。
PS: script中编写的内容,必须是空格或tab开头,如果直接跟着 “<”,是编译不出内容的。
这跟它内部的解析器有关【第一次还挺坑的…】
tick()
该函数的this对象,是当前的自定义标签的context,只要 xx(){} 这样声明的函数,context都被指定为标签的context
可通过this.tick访问 tick 函数
this.update
必须调用 this.update(); UI的内容才会更新。
可能会觉得没其它MV*的引擎自动化,但是,手动控制返回会更加灵活
opts
代码中,有个很奇怪的变量opts:
[code]this.index = opts.start || 0;
如:
[code]<timer start="10"></timer>
{ index }
riot.js强大的读值方法,它支持简单的表达式,三元判断。但是有一个坑,{}里,要用单引号\’代替双引号\”,不然超级容易解析出错。
像 { index || 10 }, { index > 10 ? ‘老头’ : ‘小屁孩’ },都可以支持
支持引用外部标签定义文件
[code]<script src="todo.tag" type="todo/tag"></script>
todo.tag的内容和编译,按照上面例子编写即可。
以上就是riot.js 学习【一】自定义标签的内容,更多相关内容请关注PHP中文网(www.php.cn)!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

本文讨论了在浏览器中优化JavaScript性能的策略,重点是减少执行时间并最大程度地减少对页面负载速度的影响。

本文讨论了使用浏览器开发人员工具的有效JavaScript调试,专注于设置断点,使用控制台和分析性能。

Python和JavaScript开发者的薪资没有绝对的高低,具体取决于技能和行业需求。1.Python在数据科学和机器学习领域可能薪资更高。2.JavaScript在前端和全栈开发中需求大,薪资也可观。3.影响因素包括经验、地理位置、公司规模和特定技能。

本文说明了如何使用源地图通过将其映射回原始代码来调试JAVASCRIPT。它讨论了启用源地图,设置断点以及使用Chrome DevTools和WebPack之类的工具。

深入探讨console.log输出差异的根源本文将分析一段代码中console.log函数输出结果的差异,并解释其背后的原因。�...

如何在JavaScript中将具有相同ID的数组元素合并到一个对象中?在处理数据时,我们常常会遇到需要将具有相同ID�...
