2017年试试Web组件化框架Omi
来源:互联网 发布:app开发需要什么软件 编辑:程序博客网 时间:2024/05/19 13:10
Open and modern framework for building user interfaces.
- Omi的Github地址https://github.com/AlloyTeam/omi
- 如果想体验一下Omi框架,请点击Omi Playground
- 如果想使用Omi框架,请阅读 Omi使用文档
- 如果想一起开发完善Omi框架,有更好的解决方案或者思路,请阅读 从零一步步打造web组件化框架Omi
- 关于上面的两类文档,如果你想获得更佳的阅读体验,可以访问Docs Website
- 如果你懒得搭建项目脚手架,可以试试Scaffolding for Omi,npm安装omis便可
- 如果你有Omi相关的问题可以New issue
- 如果想更加方便的交流关于Omi的一切可以加入QQ的Omi交流群(256426170)
特性
- 超小的尺寸,7 kb (gzip)
- 局部CSS,HTML+ Scoped CSS + JS组成可复用的组件。不用担心组件的CSS会污染组件外的,Omi会帮你处理好一切
- 更自由的更新,每个组件都有update方法,自由选择时机进行更新。你也可以和obajs或者mobx一起使用来实现自动更新。
- 模板引擎可替换,开发者可以重写Omi.template方法来使用任意模板引擎
- 完全面向对象,函数式和面向对象各有优劣,Omi使用完全的面向对象的方式来构建Web程序。
- ES6+ 和 ES5都可以,Omi提供了ES6+和ES5的两种开发方案。你可以自有选择你喜爱的方式。
通过npm安装
npm install omi
Hello World
class Hello extends Omi.Component { constructor(data) { super(data); } style () { return ` h1{ cursor:pointer; } `; } handleClick(target, evt){ alert(target.innerHTML); } render() { return ` <div> <h1 onclick="handleClick(this, event)">Hello ,{{name}}!</h1> </div> `; }}Omi.render(new Hello({ name : "Omi" }),"body");
[点击这里->在线试试]
你可以使用Omi.makeHTML来生成组件标签用于嵌套。
Omi.makeHTML('Hello', Hello);
那么你就在其他组件中使用,并且通过data-*的方式可以给组件传参,如:
... render() { return ` <div> <div>Test</div> <Hello data-name="Omi" /> </div> `; } ...
[点击这里->在线试试]
你可以使用 webpack + babel,在webpack配置的module设置babel-loader,立马就能使用ES6+来编写你的web程序。
当然Omi没有抛弃ES5的用户,你可以使用ES5的方式编写Omi。
ES5方式
var Hello = Omi.create("Hello", { style: function () { return "h1{ cursor:pointer }"; }, handleClick: function (dom) { alert(dom.innerHTML) }, render: function () { return ' <div><h1 onclick="handleClick(this, event)">Hello ,{{name}}!</h1></div>' }});var Test = Omi.create("Test", { render: function () { return '<div>\ <div>Test</div>\ <Hello data-name="Omi" />\ </div>' }});Omi.render(new Test(),'#test');
和ES6+的方式不同的是,不再需要makeHTML来制作标签用于嵌套,因为 Omi.create的第一个参数的名称就是标签名。
[点击这里试试ES5写Omi程序]
加入Omi吧!
Github: https://github.com/AlloyTeam/omi
I need you.
0 0
- 2017年试试Web组件化框架Omi
- 2017年试试Web组件化框架Omi
- 2017年试试Web组件化框架Omi
- 2017年试试Web组件化框架Omi
- Omi教程-组件
- Omi教程-组件
- Omi教程-组件
- Omi教程-组件通讯
- Omi教程-组件通讯
- Omi教程-组件通讯
- Omi教程-组件通讯
- Omi教程-组件通讯
- Omi教程-组件通讯
- 构建web组件框架
- Omi框架Store体系的前世今生
- Omi原理-Hello Omi
- Omi原理-Hello Omi
- Omi原理-Hello Omi
- Repeating Decimals UVA - 202
- 路由器和交换机的区别
- 面试题-J2SE基础(一)
- c语言之辗转相除法实现十进制转换为八进制
- Java 帝国之消息队列
- 2017年试试Web组件化框架Omi
- cordova-plugin-wechat插件的使用
- 建立一个个人网站(第二弹——作为一个程序猿)
- JSP之application对象
- hihocoder #1077 RMQ问题再临-线段树
- 移动安全资源大全
- 数据结构实验之二叉树一:树的同构
- Qt 自定义 信号与槽
- 2017-2-8get