V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
coraline
V2EX  ›  分享创造

WFrame,基于 gulp 的前端开发工具

  •  
  •   coraline · 2015-07-08 09:27:32 +08:00 · 2729 次点击
    这是一个创建于 3437 天前的主题,其中的信息可能已经有所发展或是发生改变。

    Github

    https://github.com/LoeiFy/WFrame

    文件说明

    ├── assets                 develop assets
    │   └── app                your app
    │   └── modules            css / js modules
    ├
    ├── dist                   js / css generate by gulp
    ├
    ├── html                   html generate by gulp
    ├
    ├── templates              develop html
    │   └── app                your app
    │   └── modules            html modules
    ├
    ├── gulpfile.js                                     
    ├── package.json
    

    使用

    安装 gulp

    sudo npm i gulp -g
    npm install
    

    可选安装

    • weinre 用于移动设备调试.
    • liveReload 用于自动刷新开发页面.
    sudo npm i weinre -g
    

    先安装 chrome extension livereload

    sudo npm i livereload -g
    

    项目 DEMO

    cd WFrame
    npm install
    
    • 线上部署命令 gulp
    • 开发命令 mode=dev gulp

    需要一个本地 web 服务器,访问:

    http://.../html/app/app.html

    特色

    1.可以定义 js / css / html 模块,然后在需要的地方引用

    ps:对于项目模块化,我的想法是本地开发模块化组件是必要的,但是不应该线上客户端用来加载依赖,应该由本地开发部署时候就完成依赖合并打包

    js:

    // js 模块 a: a.js
    
    var @@def = function(s) {
        //...
        return s
    }
    
    // 开发 app: app.js
    
    @@include('a.js', {"def": "a"})     // 等同于: var a = ... 
    
    document.addEventListener('DOMContentLoaded', function() {
        a('some')   // a 已经定义
    })
    

    经过 gulp 处理:

    // app.js (未压缩)
    
    var a = function(s) {
        //...
        return s
    }
    
    document.addEventListener('DOMContentLoaded', function() {
        a('some')
    })
    

    css:

    /* css 模块 b: b.css */
    
    #some {
        ...
    }
    
    /* 开发 app: app.css */
    
    @@include('b.css')
    .tag {
        ...
    }
    

    经过 gulp 处理:

    /* app.css (未压缩) */
    
    #some {
        ...
    }
    .tag {
        ...
    }
    

    html:

    <!-- 模块:header.html -->
    
    <meta charset="utf-8" />
    <title>@@title</title>
    <meta name="format-detection" content="telephone=no; date=no; address=no; email=no">
    <meta content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" name="viewport" />
    <link rel="icon" href="data:;base64,iVBORw0KGgo=">
    <link rel="stylesheet" href="@@css" />
    
    <!-- 模块:footer.html -->
    
    <script src="@@js"></script>
    
    <!-- 开发 html:app.html -->
    
    <!doctype html>
    <html>
    <head>
    
    @@include('header.html', {
        "title": "APP DEMO",
        "css": "@@/dist/app/app.css"
    })
    
    </head>
    <body>
    
    <h1>touch or hover to change color</h1>
    <div class="app"></div>
    <div class="app"></div>
    <div class="app"></div>
    
    @@include('footer.html', {
        "js": "@@/dist/app/app.js"
    })
    </body>
    </html>
    

    经过 gulp 处理:

    <!doctype html>
    <html>
    <head>
    
    <meta charset="utf-8" />
    <title>APP DEMO</title>
    <meta name="format-detection" content="telephone=no; date=no; address=no; email=no">
    <meta content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" name="viewport" />
    <link rel="icon" href="data:;base64,iVBORw0KGgo=">
    <link rel="stylesheet" href="/dist/app/app.css" />
    
    
    </head>
    <body>
    
    <h1>touch or hover to change color</h1>
    <div class="app"></div>
    <div class="app"></div>
    <div class="app"></div>
    
    <script src="/dist/app/app.js"></script>
    
    </body>
    </html>
    

    2.可以自动生成 MD5 版本号

    <!-- app.css MD5 timestamp --> 
    <link rel="stylesheet" href="/dist/app/app.css?9a8bd5e6fd21c883e0c5e3ab7e37a171">
    
    <!-- app.js MD5 timestamp -->
    <script src="/dist/app/app.js?0103f9dcd3e1493452f217064e17f12e"></script>
    

    3.自动添加 jshint 出错信息提醒

    当 jshint 检测出错,会自动在主体开发 js 文件上添加一句 alert 信息提醒出错

    alert("(error) dist/app/app.js: line 59, col 18, if (i = 5) { , Expected a conditional expression and instead saw an assignment.")
    // app.js
    ...
    

    4.自动压缩 js / css 资源,还有 html

    线上部署产生对应文件压缩版本

    5.自动合并产生开发文件

    运行 mode=dev gulp, 当修改相应 js css 模块或者 html,都会自动产生最终开发文件并检查 js 是否有问题

    6.其他

    • 安装 liveReload 自动刷新页面

    必须安装 chrome extension livereload

    cd WFrame
    # 检测 dist,html 目录的文件变化,然后自动刷新页面
    livereload dist html
    
    • weinre 用于远程调试移动端页面
    # 主机上运行
    weinre --boundHost [your ip]
    
    // 一个例子:项目中引用 js
    
    var i = 0;
    $('id').on('click', function() {
        i ++;
        if (i == 5) {
            i = 0;
    
            var ip = prompt('your ip', '');
            if (!ip) return;
    
            var e = document.createElement('script');
            e.setAttribute('src', 'http://'+ ip +':8080/target/target-script-min.js')
            document.getElementsByTagName('body')[0].appendChild(e)
        }
    })
    

    现在,可以远程调试了,访问:

    http://[your ip]:8080/client/#anonymous

    License

    MIT

    6 条回复    2015-07-09 15:44:40 +08:00
    quix
        1
    quix  
       2015-07-08 10:16:57 +08:00
    一直觉得在文件后面? md5是一个很不好的方式..
    jayin
        2
    jayin  
       2015-07-08 11:32:28 +08:00
    cool
    icyflash
        3
    icyflash  
       2015-07-08 11:34:29 +08:00
    赞。这个好
    coraline
        4
    coraline  
    OP
       2015-07-08 14:25:40 +08:00
    @quix 这样避免了手动添加版本号,虽然长了点,但是也不错,zhihu 也是类似这样做法,但他的是 MD5 文件名
    quix
        5
    quix  
       2015-07-08 15:07:10 +08:00
    @coraline 文件名要好很多, 用参数的方式很多情况下不利于利用浏览器缓存
    zhea55
        6
    zhea55  
       2015-07-09 15:44:40 +08:00
    http协议里面明明有cache-control,为什么没有一人去读一读文档,静下心来学习学习。

    就知道恶心的添加时间戳,更改文件名。

    好好的缓存策略不用。还md5?有什么鸟用。真浮躁
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3491 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 11:18 · PVG 19:18 · LAX 03:18 · JFK 06:18
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.