uniapp去除console.log()

1.现象:
开发环节,页面有大量console.log(),但一个一个去除比较废力且比较笨

在这里插入图片描述

2.解决方案一:

在这里插入图片描述

if (uni.getSystemInfoSync().platform !== "devtools") {
	console.log = () => {}
}

或者

if (process.env.NODE_ENV !== 'production') {
	console.log = () => {}//开发环境去除看一下效果
}else{
	//正式环境去除
	console.log = () => {}
}

在这里插入图片描述

3.解决方案二(vue的webpack):

webpack插件:

npm install webpack@4.46.0 --save-dev

compression-webpack-plugin插件:

npm install compression-webpack-plugin@3.1.0  --save-dev
const path = require('path')
const CompressionPlugin = require("compression-webpack-plugin")

function resolve(dir) {
  return path.join(__dirname, dir)
}

// vue.config.js
module.exports = {
  /*
    Vue-cli3:
    Crashed when using Webpack `import()` #2463
    https://github.com/vuejs/vue-cli/issues/2463
   */
  // 如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。
  productionSourceMap: false,
  //qiankuan打包时放开
  //outputDir: "../dist/main",
  // 多入口配置
  // pages: {
  //   index: {
  //     entry: 'src/main.js',
  //     template: 'public/index.html',
  //     filename: 'index.html',
  //   }
  // },
  //打包app时放开该配置
  //publicPath:'/',
  configureWebpack: config => {
    //生产环境取消 console.log
    if (process.env.NODE_ENV === 'production') {
      config.optimization.minimizer[0].options.terserOptions.compress.drop_console = true
    }
  },
  chainWebpack: (config) => {
    config.resolve.alias
      .set('@$', resolve('src'))
      .set('@api', resolve('src/api'))
      .set('@assets', resolve('src/assets'))
      .set('@comp', resolve('src/components'))
      .set('@views', resolve('src/views'))

    //生产环境,开启js\css压缩
    if (process.env.NODE_ENV === 'production') {
      config.plugin('compressionPlugin').use(new CompressionPlugin({
        test: /\.(js|css|less)$/, // 匹配文件名
        threshold: 10240, // 对超过10k的数据压缩
        deleteOriginalAssets: false // 不删除源文件
      }))
    }

    // 配置 webpack 识别 markdown 为普通的文件
    config.module
      .rule('markdown')
      .test(/\.md$/)
      .use()
      .loader('file-loader')
      .end()

    // 编译vxe-table包里的es6代码,解决IE11兼容问题
    config.module
      .rule('vxe')
      .test(/\.js$/)
      .include
      .add(resolve('node_modules/vxe-table'))
      .add(resolve('node_modules/vxe-table-plugin-antd'))
      .end()
      .use()
      .loader('babel-loader')
      .end()

  },

  css: {
    loaderOptions: {
      less: {
        modifyVars: {
          /* less 变量覆盖,用于自定义 ant design 主题 */
          'primary-color': '#1890FF',
          'link-color': '#1890FF',
          'border-radius-base': '4px',
        },
        javascriptEnabled: true,
      }
    }
  },

  devServer: {
    port: 3000,
    hot: true,
    disableHostCheck: true,
    overlay: {
      warnings: false,
      errors: true,
    },
    // headers: {
    //   'Access-Control-Allow-Origin': '*',
    // },
    proxy: {
      /* '/api': {
         target: 'https://mock.ihx.me/mock/5baf3052f7da7e07e04a5116/antd-pro', //mock API接口系统
         ws: false,
         changeOrigin: true,
         pathRewrite: {
           '/jeecg-boot': ''  //默认所有请求都加了jeecg-boot前缀,需要去掉
         }
       },*/
      /* 注意:jeecgboot前端做了改造,此处不需要配置跨域和后台接口(只需要改.env相关配置文件即可)
          issues/3462 很多人此处做了配置,导致刷新前端404问题,请一定注意*/
    }
  },

  lintOnSave: undefined
}
4.解决方案三(vue的main.js):

在这里插入图片描述

  • 5
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
uni-app中使用console.log()函数有两种常见的用法。第一种用法是在开发环境中调试代码时使用,通过注释或条件语句将console.log()函数禁用,以避免在生产环境中产生多余的输出。例如,可以使用以下代码将console.log()函数禁用: ```javascript if (process.env.NODE_ENV !== 'production') { console.log = () => {} // 在开发环境中禁用console.log() } else { console.log = () => {} // 在生产环境中禁用console.log() } ``` 这样做可以在生产环境中去除console.log()语句,提高代码的性能和安全性。 第二种用法是在微信小程序项目中使用console.log()进行调试。由于平台的限制,小程序项目中不支持axios库,而是使用原生的wx.request() API进行网络请求。因此,可以通过在console.log()语句中添加调试信息来查看网络请求的结果或验证代码的执行流程。例如,在微信小程序中可以使用以下代码进行调试: ```javascript function balance(url, data) { uni.request({ url: cfg.originUrl + '/wx/mp/js_sig.do', data: { route: url }, method: 'GET', // 其他请求参数... success: res => { console.log(res) // 打印网络请求结果 }, fail: error => { console.log("请求失败!", error) // 打印请求失败信息 } }) } ``` 这样可以通过console.log()函数输出的信息来调试网络请求的过程,并查看请求的结果或错误信息。 总结起来,uni-app中的console.log()函数主要用于在开发环境中进行调试和输出调试信息,以及在微信小程序中进行网络请求的调试。在生产环境中,建议将console.log()函数禁用,以保证代码的性能和安全性。如果需要进行更复杂的网络请求操作,可以考虑使用第三方包如@escook/request-miniprogram来发起网络请求,以获得更多的功能和定制选项。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [uniapp去除console.log()](https://blog.csdn.net/weixin_53791978/article/details/127477336)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [uni-app微信公众号支付.vue](https://download.csdn.net/download/wqzeus/11460077)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [uni-app项目笔记](https://blog.csdn.net/weixin_49499875/article/details/111292539)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Sun Peng

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值