前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >零基础学习weex(三)weex工程及工具

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

作者头像
sweet说好的幸福
发布2020-12-23 10:34:12
1.4K0
发布2020-12-23 10:34:12
举报
文章被收录于专栏:sweet_iOSsweet_iOS

本篇内容: <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格式

代码语言:javascript
复制
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,如下

代码语言:javascript
复制
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文件,如果没有请开启隐藏文件。默认配置为:

代码语言:javascript
复制
{
  "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安装模块,如图:

代码语言:javascript
复制
"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>

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、Weex的项目结构
  • 二、npm
    • 初始化
      • npm run & npm run-script
        • &与&&:
          • 通配符:
            • 默认值
              • 简写
                • 参考
                • 三、webpack
                • 四、ESLint
                  • EsLint提供以下支持:
                    • EsLint提供以下几种校验:
                      • Weex如何使用EsLint?
                      • 五、Devtools
                      相关产品与服务
                      Prowork 团队协同
                      ProWork 团队协同(以下简称 ProWork )是便捷高效的协同平台,为团队中的不同角色提供支持。团队成员可以通过日历、清单来规划每⽇的工作,同时管理者也可以通过统计报表随时掌握团队状况。ProWork 摒弃了僵化的流程,通过灵活轻量的任务管理体系,满足不同团队的实际情况,目前 ProWork 所有功能均可免费使用。
                      领券
                      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档