转载请标明出处:

http://dujinyang.blog.csdn.net/

本文出自:【奥特曼超人的博客】

@

前端Vue

Vue 经过这一年的进化,模版也是相当丰富了,但在使用多界面时,个人感觉还是有点弊端,CSS的样式问题。

Vue.js(读音 /vjuː/, 类似于 view) 是一套构建用户界面的渐进式框架。

针对问题

多环境部署会引发很多问题,当然,是开发环境下了,这次博主我也引发了这个小问题,从而看到很多人对部署的环境会有疑问,毕竟Vue没有暴漏出像JAVA那样的可配置环境。

  1. SyntaxError: Unexpected token p in JSON
  • 需要区分 开发、QA、预发布、生产等多个环境,如何满足?
  • 怎么部署到服务器上自动判断呢?

对Uni-app 的使用也是这段时间好奇才去看了看,当然,并不是去看使用,而是好奇整个架构模版的生成,还是使用HBUILDER去开发,所以我们得注意两件事情:

  1. Vue 只关注视图层 , 采用自底向上增量开发的设计。
  2. Vue API 实现了数据绑定和视图组件,所以,很多人用 npm install 后都会出现package的系列问题

package.json描述

不管你安装说明组件或模版,总是会看到目录下 package.json ,那这个文件是做什么用的呢?其实这个文件相当于 config ,所以你得注意 distlib

多环境部署

很多人想要像AS或Gradle一样去描述配置环境,类似下面这种伪判断:

  1. 区分 开发、QA、预发布、生产等多个环境
  2. if (process.env.ENV === 'development') {
  3. }
  4. if (process.env.ENV === 'QA') {
  5. }
  6. if (process.env.ENV === 'pre-release') {
  7. }
  8. if (process.env.ENV === 'production') {
  9. }

会报错?来看看源码到底是为何……

查看源码获取解决方案

来看下源码,path路径读取的Key是path ,所以:

  1. const path = require('path')

其它可以忽略,重要的是下面这段:

  1. module.exports = function (content) {
  2. if (process.env.UNI_USING_COMPONENTS || process.env.UNI_PLATFORM === 'h5') {
  3. return require('./index-new').call(this, content)
  4. }
  5. this.cacheable && this.cacheable()
  6. const manifestJsonPath = path.resolve(process.env.UNI_INPUT_DIR, 'manifest.json')
  7. const manifestJson = parseManifestJson(fs.readFileSync(manifestJsonPath, 'utf8'))
  8. this.addDependency(manifestJsonPath)
  9. const pagesJson = parsePagesJson(content)
  10. if (manifestJson.transformPx === false) {
  11. process.UNI_TRANSFORM_PX = false
  12. } else {
  13. process.UNI_TRANSFORM_PX = true
  14. }
  15. if (process.env.UNI_PLATFORM === 'h5') {
  16. return require('./platforms/h5')(pagesJson, manifestJson)
  17. }
  18. const changedEmitFiles = []
  19. function checkPageEmitFile (pagePath, pageStyle) {
  20. checkEmitFile(pagePath, parseStyle(pageStyle), changedEmitFiles)
  21. }
  22. parsePages(pagesJson, function (page) {
  23. checkPageEmitFile(page.path, page.style)
  24. }, function (root, page) {
  25. checkPageEmitFile(normalizePath(path.join(root, page.path)), page.style)
  26. })
  27. const jsonFiles = require('./platforms/' + process.env.UNI_PLATFORM)(pagesJson, manifestJson)
  28. if (jsonFiles && jsonFiles.length) {
  29. jsonFiles.forEach(jsonFile => {
  30. jsonFile && checkEmitFile(jsonFile.name, jsonFile.content, changedEmitFiles)
  31. })
  32. }
  33. changedEmitFiles.forEach(name => {
  34. this.emitFile(name + '.json', emitFileCaches[name])
  35. })
  36. return ''
  37. }

有点多,抽取一下:

  1. if (manifestJson.transformPx === false) {
  2. process.UNI_TRANSFORM_PX = false
  3. } else {
  4. process.UNI_TRANSFORM_PX = true
  5. }
  6. if (process.env.UNI_PLATFORM === 'h5') {
  7. return require('./platforms/h5')(pagesJson, manifestJson)
  8. }

其它代码太多,暂时不贴了,大致意义就是解析package.json后,再去读取H5的manifest配置,所以最后发现,是manifest配置有问题,查找是多了 pubilcPath ,去掉后,SyntaxError: Unexpected token p 错误也就消失了。

因为当代路径就在目录下了,所以打包的时候会引入了config,那自己只需要再分开一份配置文件即可。

这样就解决了,当然也可以安装个cross-env ,安装代码:

  1. npm install --save-dev cross-env

这样的话,我们可以定义:

  1. "build": "cross-env BUILD_ENV=production node build/build.js",
  2. "QA": "cross-env BUILD_ENV=QA node build/build.js",
  3. "TEST": "cross-env BUILD_ENV=TEST node build/build.js"

这样就不需要另外分开一份配置了,当然,可以把当前的BUILD_ENV设置到环境变量中,如果不是常用不建议设置。

语法:

  1. cross-env xxx=xxx node build/build.js

那么最终的代码:

  1. let ENV = process.env.BUILD_ENV;
  2. if (ENV == 'production') {
  3. // 生产环境
  4. } else if (ENV == 'QA') {
  5. // 测试环境
  6. }else if(ENV== 'TEST'){
  7. // 开发测试
  8. }

也可以自己去定义个全局变量使用,或者修改index下的源码,那样比较麻烦,小编我是修改了,不过 所有的项目都能用特定的字段去使用了。


|| 版权声明:本文为博主杜锦阳原创文章,转载请注明出处。


作者:奥特曼超人Dujinyang

来源:CSDN

原文:https://dujinyang.blog.csdn.net/

版权声明:本文为博主原创文章,转载请附上博文链接!

Vue 前端uni-app多环境配置部署服务器的问题的更多相关文章

  1. 前端移动App开发环境搭建

    移动App开发环境安装 一.环境安装准备软件 二.node的安装 像安装普通软件一样,安装对应版本的node软件,安装好之后就可以运行npm命令行,比如npm init .npm install -g ...

  2. APP自动化环境配置

    做自动化很多人都不喜欢做app自动化,说实话,我也不喜欢做app自动化,但是没办法,老板给你钱,让你做,不得不做! 其实app自动化的难点就在于环境,环境OK了之后一切都和web自动化差不多,顶多就是 ...

  3. app自动化测试环境配置:adb环境配置、monkey环境配置、appium环境配置大全

    1. 安装jdk 2. 安装配置Andriod sdk 安装Andriod sdk前首先需要安装配置好jdk环境. 然后安装Android sdk 安装完成后需要配置环境变量:ANDROID_HOME ...

  4. Tomcat环境配置部署测试环境及架构

    Tomcat环境配置已经在前面介绍过了,这边就为童鞋们介绍下对于Tomcat的架构是怎么样的! Tomcat的架构包含(bin.conf.lib.logs.temp.wenapps.work)等文件夹 ...

  5. Lisp-01: 相关开发环境配置部署

    Common Lisp 学习笔记系列01 要学一门编程语言,首先需要将语言的环境配置好.如果想要个直接上手的环境,感谢日本的大神 Shirakumo,打造了一个 Common Lisp 的 IDE - ...

  6. WAMP环境配置-Apache服务器的安装

    一.下载 下载地址:http://httpd.apache.org/ 在这里就可以下载想下载的版本了 二.安装 我这次环境配置安装的是Apache-2.4.23版本! (最近我在反复安装PHP的时候出 ...

  7. idea npm vue java开发工具安装 环境配置

    感谢此链接内容作者,从前往后流程较完整详细,助我成功配置好(不知道在这之前做的一些尝试有没有影响) https://blog.csdn.net/qq_42564846/article/details/ ...

  8. 一文搞定Spring Boot + Vue 项目在Linux Mysql环境的部署(强烈建议收藏)

    本文介绍Spring Boot.Vue .Vue Element编写的项目,在Linux下的部署,系统采用Mysql数据库.按照本文进行项目部署,不迷路. 1. 前言 典型的软件开发,经过" ...

  9. Hybrid app(cordova) 环境配置记录

    node版本管理 NVM 安装过程 由于最新版 node 不兼容部分功能,所以需要安装 nvm 切换 node 版本 在 https://github.com/coreybutler/nvm-wind ...

随机推荐

  1. Paxos算法原理

    1.从ACID到CAP 我们知道传统集中式系统中实现ACID是很简单的,在分布式环境中,涉及到不同的节点,节点内的ACID可以控制,那么节点间的ACID如何控制呢?构建一个可用性和一致性的分布系统成为 ...

  2. JVM调优之经验

    在生产系统中,高吞吐和低延迟一直都是JVM调优的最终目标,但这两者恰恰又是相悖的,鱼和熊掌不可兼得,所以在调优之前要清楚舍谁而取谁.一般计算任务和组件服务会偏向高吞吐,而web展示则偏向低延迟才会带来 ...

  3. JS之null与undefined的区别

    null表示尚未存在的对象 js 代码: alert(null == document.getElementById('notExistElement'));  //output "true ...

  4. Day 01--选题与设计(一)

    1.第一天我们主要确定了软件课设的项目,做一个学校内食堂订送餐的微信小程序.我们大体的设计思路是:可以实现学生身份的认证,幷使学生们能自行选择校园内的食堂,挑选各个食堂各个窗口菜谱上可以选择的菜,选择 ...

  5. js-EventLoop

    1.浏览器事件环 eventLoop是由js的宿主环境(浏览器)来实现的 事件循环可以简单的描述为以下四个步骤 1.函数入栈,当Stack中执行到异步任务的时候,就将他丢给WebAPIs,接着执行同步 ...

  6. 快速了解Python并发编程的工程实现(上)

    关于我 一个有思想的程序猿,终身学习实践者,目前在一个创业团队任team lead,技术栈涉及Android.Python.Java和Go,这个也是我们团队的主要技术栈. Github:https:/ ...

  7. 初学html总结

    2019-08-17 17:58:49 html:超文本标记语言,用于网页结构的搭建 html语言构成:由标签.属性.属性值构成 标签:" < "后面第一个单词 属性:标签后 ...

  8. SpringMVC源码剖析5:消息转换器HttpMessageConverter与@ResponseBody注解

    转自 SpringMVC关于json.xml自动转换的原理研究[附带源码分析] 本系列文章首发于我的个人博客:https://h2pl.github.io/ 欢迎阅览我的CSDN专栏:Spring源码 ...

  9. 提交中文数据乱码问题---web.xml

    前端时间,做了个纯springmvc框架的一个后台系统,遇到了不少问题.特别是编码问题,让我纠结了很久.每次ajax传入数据的时候需要将form中的数据先进行编码 encodeURI(AA); 利用a ...

  10. INSERT: 批量插入结果集方式

    INSERT: 批量插入结果集 insert into table select x,y from A UNION select z,k from B ; insert into table sele ...