zoukankan      html  css  js  c++  java
  • asp.net core前后端分离

    陆陆续续的看了两个礼拜的前端知识,把vue+vue-router+axios的知识撸了一遍,本来想加个element-ui来实现一下前后端分离,实施的时候却遇到了很多的坑。我本身不在一个软件开发公司上班,公司又有开发应用的需求。以前公司有钱的时候都是外包出去的,现在经济不景气,向我这种的“免费午餐”就有了用武之地。但是开发一些项目也只有我一个人在搞,从数据库到前端再到后端服务器都是我一个人在搞。实在太幸苦。不为别的,能多挣点儿钱,给孩子用,就好了。先不说没用的了,这篇文章主要是记录一些前端的知识点,因为我暂时搞不下去了,先记录一下,免得白学。

    webpack

    webpack是一个打包工具,它的作用却超出了打包这个词的范围。使用vue-cli可以创建基于webpack的工程项目。webpack默认的配置文件名是webpack.comfig.js,内容如下:

    var path = require('path')
    var webpack = require('webpack')
    
    module.exports = {
      entry: './src/main.js',
      output: {
        path: path.resolve(__dirname, './dist'),
        publicPath: '/dist/',
        filename: 'build.js'
      },
      module: {
        rules: [
          {
            test: /.vue$/,
            loader: 'vue-loader',
            options: {
              // vue-loader options go here
            }
          },
          {
            test: /.js$/,
            loader: 'babel-loader',
            exclude: /node_modules/
          },
          {
            test: /.(png|jpg|gif|svg)$/,
            loader: 'file-loader',
            options: {
              name: '[name].[ext]?[hash]'
            }
          },
          {
            test: /.css$/,
            loader: "style-loader!css-loader"
          },
          {
            test: /.(eot|woff|woff2|ttf)([?]?.*)$/,
            loader: "file-loader"
          }
        ]
      },
      resolve: {
        alias: {
          'vue$': 'vue/dist/vue.common.js'
        }
      },
      devServer: {
        historyApiFallback: true,
        noInfo: true
      },
      devtool: '#eval-source-map'
    }
    
    if (process.env.NODE_ENV === 'production') {
      module.exports.devtool = '#source-map'
      // http://vue-loader.vuejs.org/en/workflow/production.html
      module.exports.plugins = (module.exports.plugins || []).concat([
        new webpack.DefinePlugin({
          'process.env': {
            NODE_ENV: '"production"'
          }
        }),
        new webpack.optimize.UglifyJsPlugin({
          sourceMap: true,
          compress: {
            warnings: false
          }
        }),
        new webpack.LoaderOptionsPlugin({
          minimize: true
        })
      ])
    }

    还要注意的是element-ui按需加载的话需要配置babel的配置文件,.balbelrc:

    {
      "presets": [["env", { "modules": false }]],
      "plugins": [
        [
          "component",
          {
            "libraryName": "element-ui",
            "styleLibraryName": "theme-chalk"
          }
        ]
      ]
    }

    以上这两个文件需要在vue init webpack xxxx生成工程后再进行修改。先记录一下,以后有时间继续搞。

    Vue

    vue是个好东西,用组件的思维对js的作用域进行了很好的封装。vue里面比较重要的概念由两个,一个就是组件,另一个就是路由,这两个是做单页面应用必须掌握的东西。当new一个Vue的时候,就是建立了一个根组件,可以在这个Vue的components属性里面塞进去别的组件,Vue有一个单文件组件的概念,创建单文件组件可以更好的组织代码。单文件组件是需要通过vue-loader来解析,后者又是基于webpack的生态的。子组件访问父组件的数据(或者说父组件给子组件传值)是利用props属性,这个属性是声明在子组件里面的,用来接收父组件传进来的值。相反方向上的话是利用子组件的$emit()来触发事件,父组件来监听这个事件,并接收事件本身传递来的值。当我们创建了很多组件,就涉及到如何在页面上进行展现的问题了,这个是用vue-router来搞的,vue-router就是给每个组件起名字,然后用<router-link>和<router-view>来定向不同的组件。在根组件的router属性上赋值的时候,可以在子组件中通过$route来进行访问,如果是一个动态的路由的话(/user/:id),可以通过$route.params来访问路由的参数值。和组件的概念类似的是,路由也可以有子路由,通过children来定义的。

  • 相关阅读:
    2017-2018-1 20155214 实验五 通讯协议设计
    2017-2018-1 20155214 《信息安全系统设计基础》第13周学习总结
    2017-2018-1 20155214 《信息安全系统设计基础》 第9周课下测试-mypwd
    2017-2018-1 20155214 《信息安全系统设计基础》 第11周学习总结
    2017-2018-1 20155214 20155335《信息安全技术基础》 实验3
    2017-2018-1 20155214 《信息安全系统设计基础》实验三 并发程序
    2017-2018-1 20155214 《信息安全系统设计基础》 第9周学习总结
    2017-2018-1 20155214 《信息安全系统设计基础》 第8周学习总结
    2017-2018-1 20155214 《信息安全系统设计基础》 第8周课下作业
    2017-2018-1 20155214 《信息安全系统设计基础》 第7周学习总结
  • 原文地址:https://www.cnblogs.com/pangjianxin/p/8996461.html
Copyright © 2011-2022 走看看