執行完omi init my-app
,你能夠看到會生成以下的基礎目錄結構javascript
my-app/ config project.js config.js src/ component css img js libs page index page-b favicon.ico
當你執行 npm start
會自動打開 http://localhost:9000/。如今你能夠開始開發和調試,修改代碼而且保存,瀏覽器會自動刷新顯示最新的結果。css
當你執行 npm run dist
以後,會建立一個dist目錄,全部要發佈的文件都在裏面:html
my-app/ dist/ chunk component css img js libs favicon.ico index.html page-b.html
component會保留其依賴的某些資源文件,chunk會輸出分割出來的模板,怎麼分割請往下看。java
爲了優化性能,用戶不須要一次性加載全部網頁的依賴,能夠在須要使用的時候再進行加載,因此這部分能夠進行分割成單獨的模塊。
以下面的a.js:webpack
import logo from '../../img/omi.png' module.exports = { src: logo }
經過require.ensure進行按需使用,在用戶點擊事件觸發以後纔會進行加載a.js以及a.js的全部依賴,以下面代碼所示:git
class Hello extends Omi.Component { constructor(data, option){ super(data, option) } handleClick(){ require.ensure(['./a.js'], function() { var a = require("./a.js") document.body.innerHTML+=`<img src="${a.src}">` }) } render() { return ` <div class="App"> <div class="App-header"> <img src='${logo}' onclick="handleClick" class="App-logo" alt="logo" /> <h2>Welcome to Omi</h2> </div> <p class="App-intro"> To get started, edit <code>src/component/hello.js</code> and save to reload. </p> <p class="App-intro"> {{name}} </p> </div> ` } }
上面是老的方式,webpack2更加建議使用一種"類函數式(function-like)"的 import() 模塊加載語法。如:github
import("./a.js").then(function(moduleA) { console.log(moduleA); document.body.innerHTML+=`<img src="${moduleA.src}">` });
這樣也能達到一樣的效果,固然你也可使用async/await。web
Omi框架是能夠兼容IE8的。npm
因爲使用了webpack-hot-middleware
, 開發過程不兼容IE8,可是不要緊,npm run dist
生成的發佈代碼是兼容IE8。瀏覽器
須要主要的是,你須要在你的HTML裏引用es5-sham或者es5-shim。如:
<!--[if lt IE 9]> <script type="text/javascript" crossorigin="anonymous" src="//s.url.cn/qqun/xiaoqu/buluo/p/js/es5-sham-es5-sham.min.77c4325f.js"></script> <![endif]-->
經過import能夠在js依賴相關的css文件,
import './index.css'
index.css會被提取到CSS文件當中,插入到head裏面。
import './index.css' class Hello extends Omi.Component { constructor(data, option){ super(data, option) } style(){ return require('./_hello.css') } ... ... }
Omi框架的style方法返回的字符串會生成爲組件的局部CSS,_hello.css
文件會在運行時動態插入到head裏面。
須要特別注意的是: 組件的局部CSS必須使用下劃線開頭,如_xxx.css
,_aaa-bbb.css
,否則會被識別成全局CSS插入到head裏。
固然不是必須require外部的css文件,也能夠直接寫在style方法內,組件的依賴的圖片資源也在組件的目錄內:
my-app/ src/ component hello index.js pen.png pencil.png
對應的index.js以下所示:
class Hello extends Omi.Component { constructor(data, option){ super(data, option) } style(){ return ` .icon-pen { background-image: url(${require('./pen.png')}); } .icon-pencil { background-image: url(${require('./pencil.png')}); } ` } ... ... }
經過import能夠在js依賴相關的css文件,
import './xxx.less'
xxx.less會在轉換成CSS,而且被提取到CSS文件當中,插入到head裏面。
class Intro extends Omi.Component { constructor(data, option){ super(data, option) } style(){ return require('./_index.less') } render() { return ` <p class="app-intro"> To get started, edit <code>src/component/hello.js</code> and save to reload. </p> ` } } export default Intro
Omi框架的style方法返回的字符串會生成爲組件的局部CSS,_index.css
文件會在運行時動態插入到head裏面。
須要特別注意的是: 組件的局部Less必須使用下劃線開頭,如_xxx.css
,_aaa-bbb.css
,否則會被識別成全局CSS插入到head裏。
如上面一節定義了Intro
組件,利用複用。那麼怎麼在其餘組件中使用?
import Intro from '../intro/index.js' Omi.tag('intro',Intro) class XXX extends Omi.Component { constructor(data, option){ super(data, option) } render() { return ` <div> <div>Hello Omi!</div> <intro></intro> </div> ` } } export default XXX
經過Omi.tag('intro',Intro)
把組件Intro生成爲能夠聲明式的標籤。注意便籤名字要使用小寫,多個單詞使用中劃線,如:my-intro
、app-header
等。
如上面的例子:
import logo from './logo.svg'
logo.svg會被動態轉成base64。咱們能夠爲每種類型都對應webpack裏的一個loader來處理全部的文件類型。
打開 config.js
,其位置以下:
my-app/ config project.js **config.js**
打開以後能夠看到
module.exports = { "webserver": "//localhost:9000/", "cdn": "", "port": "9000", "route": "/news/", };
module.exports = { "webserver": "//localhost:9000/", "cdn": "//s.url.cn/", "port": "9000", "route": "/news/", };
module.exports = { "webserver": "//localhost:9000/", "cdn": "//s.url.cn/", "port": "9001", "route": "/news/", };
module.exports = { "webserver": "//localhost:9001/", "cdn": "//s.url.cn/", "port": "9001", "route": "/user/", };