• 欢迎访问web前端中文站,JavaScript,CSS3,HTML5,web前端demo
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏web前端中文站吧

2017年试试Web组件化框架Omi

JavaScript web前端中文站 2年前 (2017-04-14) 1134次浏览 已收录 0个评论

2017 年试试 Web 组件化框架 Omi

Open and modern framework for building user interfaces.


  • Omi的 Github 地址 https://github.com/AlloyTeam/omi
  • 如果想体验一下Omi框架,可以访问 Omi Playground
  • 如果想使用Omi框架或者开发完善Omi框架,可以访问 Omi使用文档
  • 如果你想获得更佳的阅读体验,可以访问 Docs Website
  • 如果你懒得搭建项目脚手架,可以试试 omi-cli
  • 如果你有 Omi 相关的问题可以 New issue

特性

  • 超小的尺寸,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
<style>
h1{
cursor:pointer;
}
</style>
}
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>
`;
}
...

注意,style 方法里面 return 包裹的<style></style>不是必须的。主要是方便识别成 jsx 文件时候有 css 语法高亮。

你可以使用 webpack + babel,在 webpack 配置的 module 设置 babel-loader,立马就能使用 ES6+来编写你的 web 程序。

当然 Omi 没有抛弃 ES5 的用户,你可以使用 ES5 的方式编写 Omi。

ES5 方式

var Hello =Omi.create("Hello", {
style: function () {
return "<style>h1{ cursor:pointer }</style>";
},
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 的第一个参数的名称就是标签名。

加入 Omi 吧!

Github: https://github.com/AlloyTeam/omi

I need you.


web 前端中文站 , 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:2017 年试试 Web 组件化框架 Omi
喜欢 (0)
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址