Open and modern framework for building user interfaces. Omi的Github地址 "https://github.com/AlloyTeam/omi" 如果想體驗一下Omi框架,請 "點擊Omi Playground" 如果想使用Omi框架,請 ...
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的第一個參數的名稱就是標簽名。
加入Omi吧!
Github: https://github.com/AlloyTeam/omi
I need you.