零基础学习weex(三)weex工程及工具

本篇内容:
<pre>
Weex的项目结构
npm
webpack
ESLint
Devtools
</pre>

一、Weex的项目结构

通过weex init WeexDemo创建一个WeexDemo工程,结构及对应的功能如下:

<pre>
├──assets #资源目录 用于prew页面二维码
│ ├──qrcode.min.js
│ ├──qrcode.js
│ ├──url.js
│ └──style.css
├──build #编译生成ip地址的配置文件录
│ └──init.js
├──dist #编译出来的js目录
│ ├──app.web.js #web端使用这个文件
│ └──app.weex.js #native使用这个文件
├──node_modules #项目依赖包
├──src #源码目录
│ └──foo.vue
├──.babelrc #babel配置文件
├──.eslintrc #eslint配置文件
├──.gitignore
├──index.html #web端页面和二维码预览页面
├──weex.html #web端页面
├──package.json #npm的配置文件
├──app.js #声明的vue实例
└──webpack.config.js #webpack配置文件
</pre>

二、npm

在搭建weex环境中我们就引入了npm,那时候主要是用作JavaScript包管理工具,此章主要介绍npm script。npm对应的文件是package.json,定义在package.json里面的脚本,就称为npm脚本。下图是创建weex时默认生成的package.json:


packageJson.jpg
  • 上面的一部分是项目相关信息
  • scripts节点就是我们要研究的npm 脚本
  • dependencies节点是项目发布的依赖
  • devDependencies 节点是项目开发工具

初始化

npm init,配置对应的参数,如git repo,name,version之类。

npm run & npm run-script

这两命令的效果都是一样的,都能执行 package.json 文件 scripts 字段下指定的任务

&与&&:

  • &表示并行执行(即同时的平行执行),例如$ npm run script1.js & npm run script2.js同时执行
  • &&表示继发执行(即只有前一个任务成功,才执行下一个任务),例如$ npm run script1.js && npm run script2.js,先执行script1.js,执行完后执行script2.js

通配符:

表示任意文件名,*表示任意一层子目录,例如:
"lint": "jshint *.js"
"lint": "jshint */.js"

默认值

npm 对两个脚本提供了默认值,这两个脚本不用定义,就可以直接使用,如下:
"start": "node server.js",
"install": "node-gyp rebuild",前提是项目根目录下有binding.gyp文件

简写

npm start是npm run start
npm stop是npm run stop的简写
npm test是npm run test的简写
npm restart是npm run stop && npm run restart && npm run start的简写

参考

三、webpack

webpack 简单的说就是一个打包工具,可以通过配置loader,将各种JS(比如Vue, Coffee, JSX等),样式(css,sass,less,stylus等等),图片资源进行打包。
webpack 一大优点是可以通过配置loader,加载我们的的类型文件,也可以做一些代码压缩,预处理,代码风检测,别名的设置 下面附上一些设置的例子,仅供参考 配置 scss, sass的 loader,将图片转化成base64格式

resolve: {
    extensions: ['', '.js', '.vue'],
    fallback: [path.join(__dirname, '../node_modules')],
    alias: {
      'components': path.resolve(__dirname, './src/components'),    # 配置别名  在js或者vu中可以使用别名,简化导入文件的路径
      'common': path.resolve(__dirname, './src/common'),
      'utils': path.resolve(__dirname, './src/utils'),
      'examples': path.resolve(__dirname, './src/examples'),
      'style': path.resolve(__dirname, './src/style'),
      'filters': path.resolve(__dirname, './src/filters'),
      'mixins': path.resolve(__dirname, './src/mixins')
    }
  },
  preLoaders: [                             # 配置eslint  将对vue 和js 文件做代码风格检查
      {
        test: /\.vue$/,
        loader: 'eslint',
        exclude: /node_modules/
      },
      {
        test: /\.js$/,
        loader: 'eslint',
        exclude: /node_modules/
      }
    ],
loaders: [
      {
        test: /\.js$/,
        loader: 'babel',
        exclude: /node_modules/
      },
      {
        test: /\.css$/, loader: 'style-loader!css-loader'               # 配置css 的loader
      },
      {
        test: /\.(scss|sass)$/, loader: 'style-loader!css-loader!sass-loader'   # 配置scss sass的loader
      },
      {
        test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,                  # 将图片转化成base64格式
        loader: 'url',
        query: {
          limit: 10000,
          name: '[name].[ext]'
        }
      },
    ]

四、ESLint

ESLint 是由 Nicholas C. Zakas 编写的一个可扩展、每条规则独立、不内置编码风格为理念的 Lint 工具。
简单来说,Eslint 是一个JavaScript验证工具,有了它可以让你的编辑器像ide一样进行一些静态的错误提示功能。一方面团队协作中能够统一团队代码风格化,另一方面能够提前知道可能会存在的问题,避免低级 Bug。比如在Javascript应用中,你很难找到你漏泄的变量或者方法。EsLint能够帮助我们分析JS代码,找到bug并确保一定程度的JS语法书写的正确性。

EsLint提供以下支持:

  • ES6
  • AngularJS
  • JSX
  • Style检查
  • 自定义错误和提示

EsLint提供以下几种校验:

  • 语法错误校验
  • 不重要或丢失的标点符号,如分号
  • 没法运行到的代码块
  • 未被使用的参数提醒
  • 漏掉的结束符,如}
  • 确保样式的统一规则,如sass或者less
    -检查变量的命名

Weex如何使用EsLint?

在创建Weex工程后webpack中有一段注释就是提示你应该用一下 ESLint,如下

module: {
      // // You can use ESLint now!
      // // Please:
      // // 1. npm install {
      // //   babel-eslint
      // //   eslint
      // //   eslint-config-standard
      // //   eslint-loader
      // //   eslint-plugin-html
      // //   eslint-plugin-promise
      // // } --save-dev
      // // 2. set .eslintrc
      // //   take { "extends": "standard" } for example
      // //   so you need: npm install eslint-plugin-standard --save-dev
      // // 3. set the config below
      // preLoaders: [
      //   {
      //     test: /\.vue$/,
      //     loader: 'eslint',
      //     exclude: /node_modules/
      //   },
      //   {
      //     test: /\.js$/,
      //     loader: 'eslint',
      //     exclude: /node_modules/
      //   }
      // ],

并且创建完Weex项目后,一般目录下面会有.eslintrc文件,如果没有请开启隐藏文件。默认配置为:

{
  "root": true,
  "parser": "babel-eslint",
  "parserOptions": {
    "sourceType": "module"
  },
  "globals": {
    "Vue": false,
  },
  "extends": "standard",
  "plugins": [
    "html"
  ],
  "rules": {
    "arrow-parens": 0,
    "generator-star-spacing": 0,
  }
}

解释一下:

  • root
    默认情况下,ESLint 会在所有父级目录里寻找配置文件,一直到根目录。为了将 ESLint 限制到一个特定的项目,在你项目根目录下的 package.json 文件或者 .eslintrc.* 文件里的 eslintConfig 字段下设置 “root”: true。ESLint 一旦发现配置文件中有 “root”: true,它就会停止在父级目录中寻找。
  • parser
    ESLint 默认使用Espree作为其解析器
  • globals
    当访问未定义的变量时,no-undef 规则将发出警告。如果你想在一个文件里使用全局变量,推荐你定义这些全局变量,这样 ESLint 就不会发出警告了。你可以使用注释或在配置文件中定义全局变量。
  • extends
    一个配置文件可以被基础配置中的已启用的规则继承。
  • plugins
    一个 npm 包,通常输出规则。一些插件也可以输出一个或多个命名的 配置。要确保这个包安装在 ESLint 能请求到的目录下。plugins 属性值 可以省略包名的前缀 eslint-plugin-。
  • rules
    规则。请参考官方文档 。

1、安装
你可以自己使用npm安装:npm install -g eslint
你也可以在Weex工程中配置, 在package.json 的devDependencies加入注释中表明的安装依赖,重新使用npm install安装模块,如图:

"devDependencies": {
    "babel-core": "^6.20.0",
    "babel-loader": "^6.2.9",
    "babel-preset-es2015": "^6.18.0",
    "css-loader": "^0.26.1",
    "ip": "^1.1.4",
    "serve": "^1.4.0",
    "vue-loader": "^10.0.2",
    "vue-template-compiler": "^2.1.8",
    "webpack": "^1.14.0",
    "weex-devtool": "^0.2.64",
    "weex-loader": "^0.4.1",
    "weex-vue-loader": "^0.2.5",
    "url-loader": "^0.5.7",

    "babel-eslint": "^7.1.1",
    "eslint": "^3.16.1",
    "eslint-config-standard": "^6.2.1",
    "eslint-config-weex": "^0.1.4",
    "eslint-loader": "^1.6.3",
    "eslint-plugin-html": "^2.0.1",
    "eslint-plugin-promise": "^3.4.2",
    "eslint-plugin-standard": "^2.0.1"
  }

2、打开webpack中preLoaders
3、重新打包,npm run dev,如果有代码风格问题,会自动报错。当然,有些警告并不影响程序运行,只是为了统一风格。

五、Devtools

Weex 开发了一套 Weex Devtools,它与 Chrome Devtools 极为相似,学习成本很低,目前只支持在 Chrome 浏览器里使用。在终端输入weex debug指令(最新版本 starter kit 添加了 npm run debug 支持),会弹出 Weex Devtools,打开 Playground,扫描 Devtools 的二维码来启动 Debugger。
这块讲解起来比较繁杂,需要在使用过程中摸索,饿了么讲解的不错传送门;github上也有也经典讲解https://github.com/weexteam/article/issues/50

<pre>
Tip:学习的过程中要多看别人的开源源码,推荐两个AppStore能下载的app,附上开源链接

1、WeexPlayground官方的demo,基础组件的学习👍

2、煎蛋(https://github.com/totzcc/WeexHTMLParse)
</pre>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容

  • 2016年4月21日,阿里巴巴在Qcon大会上宣布开源跨平台移动开发工具Weex,Weex能够完美兼顾性能与动态性...
    晴天咚咚阅读 2,889评论 1 15
  • GitChat技术杂谈 前言 本文较长,为了节省你的阅读时间,在文前列写作思路如下: 什么是 webpack,它要...
    萧玄辞阅读 12,689评论 7 110
  • 写在开头 先说说为什么要写这篇文章, 最初的原因是组里的小朋友们看了webpack文档后, 表情都是这样的: (摘...
    Lefter阅读 5,285评论 4 31
  • 无意中看到zhangwnag大佬分享的webpack教程感觉受益匪浅,特此分享以备自己日后查看,也希望更多的人看到...
    小小字符阅读 8,160评论 7 35
  • 作者:小 boy (沪江前端开发工程师)本文原创,转载请注明作者及出处。原文地址:https://www.smas...
    iKcamp阅读 2,757评论 0 18