zoukankan      html  css  js  c++  java
  • 重复的事情让机器来做,简化的思想

    我们的工作是干什么的?程序是干什么的?

    答案是解决问题。


    今天突然被唤醒了,像是武学菜鸟的顿悟。我们所讨厌某些框架,讨厌做某些事情,也许是因为重复。

    细细想来,让重复的事情变得简单,不是很有意思吗。

    今天看了下 vue-cli 中 build 的一段代码(来源于 基于webpack3 的 vue-cli)

      // generate loader string to be used with extract text plugin
      function generateLoaders (loader, loaderOptions) {
        const loaders = options.usePostCSS ? [cssLoader, postcssLoader] : [cssLoader]
    
        if (loader) {
          // loader = stylus/less/sass
          // loaderOptions = 我们自己做的一些其他配置
          // 这里的最底层都用了 css-loader,相当于我们自己不用重复写这些东西
          // 
          loaders.push({
            loader: loader + '-loader',
            options: Object.assign({}, loaderOptions, {
              sourceMap: options.sourceMap
            })
          })
        }
    
        // Extract CSS when that option is specified
        // (which is the case during production build)
        if (options.extract) {
          return ExtractTextPlugin.extract({
            use: loaders,
            fallback: 'vue-style-loader'
          })
        } else {
          return ['vue-style-loader'].concat(loaders)
        }
      }
    

    它呢,可以让我们简单地配置 stylus-loader/less-loader,我想,这样一段代码,简化了 webpack 的配置,也许,它就是 parcel 和 webpack4 的一些思想,它就是简化的思想。

    重复的事情让机器来做,回想起在万科的科技部门实习的时候,部门 Leader 说过的一句话。

    Gulp的作用主要是打包的自动化,重复的事情,压缩代码,用机器来做,提升了生产力。

    又想起了看 Express 中的官网的东西,最近复习的时候反而回忆起以前做过的一些蠢事

    app.route('/book')
      .get(function (req, res) {
        res.send('Get a random book')
      })
      .post(function (req, res) {
        res.send('Add a book')
      })
      .put(function (req, res) {
        res.send('Update the book')
      })
    

    上面是 Express 官网示范的一些 API 接口,而我记得我曾经写的时候却将之一个个拆分,这其中多余的部分完全可以用这种结构写的。


    工作效率,代码的优雅,也许都靠这一些些简化。

    complete.

  • 相关阅读:
    sql的优化
    使用Robo 3T访问MongoDB数据库
    在IDEA中用三个jar包链接MongoDB数据库——实现增删改查
    使用Robo 3T操作MongoDB数据库
    MongoDB 创建数据库
    mysql本地中127.0.0.1连接不上数据库怎么办
    IDEA-Maven的Dependencies中出现红色波浪线
    log4j2+slf4j+junit
    fastxml Jackson annotation使用小记
    我理解的互联网技术领域
  • 原文地址:https://www.cnblogs.com/can-i-do/p/10977957.html
Copyright © 2011-2022 走看看