资讯专栏INFORMATION COLUMN

Vue学习笔记

gecko23 / 2921人阅读

摘要:如果全部钩子执行完了,则导航的状态就是确认的。中断当前的导航。如果浏览器的改变了可能是用户手动或者浏览器后退按钮,那么地址会重置到或者跳转到一个不同的地址。

githubhttps://github.com/cd-dongzi/vue-example

1. 解决css背景图片打包路径错误的问题

在utils.js 文件中 找到 generateLoaders 方法

把以下代码进行更换

    if (options.extract) {
        return ExtractTextPlugin.extract({
            use: loaders,
            fallback: "vue-style-loader"
        })
    } else {
        return ["vue-style-loader"].concat(loaders)
    }

更换成

    if (options.extract) {
        return ExtractTextPlugin.extract({
            use: loaders,
            fallback: "vue-style-loader",
            publicPath: "../../"
        })
    } else {
        return ["vue-style-loader"].concat(loaders)
    }

打包就可以看到效果咯!

2. Vue引入全局less变量

用vue-cli初始化的vue项目

再build文件夹下创建一个globalLessVars.js文件

在globalLessVars.js文件中 放入如下代码

    const fs = require("fs");
    module.exports = function getLessVariables(file) {
        var themeContent = fs.readFileSync(file, "utf-8")
        var variables = {}
        themeContent.split("
").forEach(function(item) {
            if (item.indexOf("//") > -1 || item.indexOf("/*") > -1) {
                return
            }
            var _pair = item.split(":")
            if (_pair.length < 2) return;
            var key = _pair[0].replace("
", "").replace("@", "")
            if (!key) return;
            var value = _pair[1].replace(";", "").replace("
", "").replace(/^s+|s+$/g, "")
            variables[key] = value
        })
        return variables
    }

在utils.js 引入 globalLessVars.js文件

const globalLessVars = require("./globalLessVars");

在static文件中创建 color.less 文件

在 color.less 文件中 放入如下代码

    @theme-color: #c1866a;
    @vice-color: rgba(186,164,119,0.99);
    @blue-color: #2e90fe;

在util.js文件中如下解析 color.less 文件

    const colorsLess = globalLessVars(path.join(__dirname, "../static/color.less"));

再把util.js 文件中 cssLoaders方法中返回值改成以下代码

    return {
        css: generateLoaders(),
        postcss: generateLoaders(),
        less: generateLoaders("less", {
            globalVars: colorsLess
        }),
        sass: generateLoaders("sass", { indentedSyntax: true }),
        scss: generateLoaders("sass"),
        stylus: generateLoaders("stylus"),
        styl: generateLoaders("stylus")
    }
大功告成

引用多个文件的话 就这可以这样

    const colorsLess = getLessVariables(path.join(__dirname, "../static/color.less"));
    const stylesLess = getLessVariables(path.join(__dirname, "../static/style.less"));
    const allLess = Object.assign(colorsLess, stylesLess);
    
    less: generateLoaders("less", {
         globalVars: allLess
    })

具体详情可以查看使用webpack+vue+less开发,使用less-loader,配置全局less变量
3. 去除vue项目中的 # --- History模式
    export default new Router({
        mode: "history",
        routes: [
           ...
        ]
    })
如果后台没给前端的 history 模式 匹配路径的话, history 只适合在本地开发使用, 打包记得改回 hash 模式
4. 自定义路径名

import HelloWorld from "@/components/HelloWorld"

制定像 @ 这样的自定义名称

可以前往 webpack.base.conf.js 中如下设置:

    resolve: {
        extensions: [".js", ".vue", ".json"],
        alias: {
            "vue$": "vue/dist/vue.esm.js",
            "@": resolve("src"),
            "components": resolve("src/components"),
            "views": resolve("src/views")
        }
    }

5. 不符合规范导致eslint代码检测工具报错

如果出现类似以上的错误 , 前往 build 文件下 webpack.base.conf.js  中注释调 eslint-loader  这个loader  就行了

如果你不想使用eslint 代码检测 你可以在用vue-cli直接在创建vue项目的时候就选择不生成代码检测这个eslint-loader
6. 本地开发解决跨域请求的问题

在 config 文件下的 index.js 文件中修改以下代码

    proxyTable: {}
    

设置成

    proxyTable: {
        "/api": {
            target: "http://www.mytest.com", //这里放需要请求的接口
            changeOrigin: true,
            pathRewrite: {
                "^/api": ""
            }
        }
    } 
    
    //  请求接口的时候 http://www.mytest.com/login  可以写成  /api/login

可以发起多个代理 (如下):

    proxyTable: {
        "/api": {
            target: "http://www.mytest.com", 
            changeOrigin: true,
            pathRewrite: {
                "^/api": ""
            }
        },
        "/a": {
            target: "http://www.test.com", 
            changeOrigin: true,
            pathRewrite: {
                "^/a": ""
            }
        }
    }

7. babel-polyfill 让ie上使用新语法的内置对象和API

npm i babel-polyfill --save 下载 babel-polyfill 模块

在webpack.base.conf.js 中做以下修改

    module.exports = {
        entry: {
          app: ["babel-polyfill", "./src/main.js"]
        },
        ......
    }
    
8. 前台拦截器

一般在我们请求后台数据时,都会在请求过程中执行动画, 和统一管理请求错误,验证TOKEN 等等的情况;
当你使用 axios 做请求时, 你可以做如下设置来解决以上问题

npm i axios qs --save 来下载这两个模块

创建fetch.js 文件,内容如下:

    
    import axios from "axios"
    import qs from "qs"  // 直接post请求后台取不到参数,()

    // 发起请求时,会执行该方法
    axios.interceptors.request.use(config => {
        //你可以在这里开始加载动画,  查询token  等等之类
        return config
    }, err => {
        return Promise.reject(err)
    })

    //接收到后台的数据时执行的方法
    axios.interceptors.response.use(response => response, err => Promise.resolve(err.response))


    //检查状态码 status
    function checkStatus(res) {
        if (res.status === 200 || res.status === 304) { //当状态正常是返回原样的数据
            return res
        }
        return {  // 状态不正常时可以返回自己自定义的一些格式或者状态什么的
            ....
        }
    }

    //检查后台的code 值
    function checkCode(res) {
        if (res.data.code === 0) {  //code值错误时
            alert("出错了")
        }
        return res
    }


    export default {
        get(url, params) {  //返回封装后的 get 方法
            if (!url) return
            return axios({
                method: "get",
                url,
                params,
                timeout: 10000
            }).then(checkStatus).then(checkCode)
        },
        post(url, data) { //返回封装后的 post 方法
            if (!url) return
            return axios({
                method: "post",
                url,
                data: qs.stringify(data),
                timeout: 10000
            }).then(checkStatus).then(checkCode)
        }
    }
   //在main.js中引入封装后的axios  
    import http from "./utils/fetch"
    
    Vue.prototype.http = http;
post请求直接放参数, 为何后台接收不到前端的参数 axios发送post请求,springMVC接收不到数据问题
9. Vue数组更新, 却无法渲染问题

可以使用Vue.$set(object, key, value)来解决这个问题

具体可以参考这里 变化检测问题(数组相关)
10. 路由懒加载
    export default new Router({
        routes: [
            {
                path: "/lazy",
                name: "lazy-loading",
                component: (resolve) => {  //这里加载了 记得上面就不需要在import 这个组件了
                    require(["../components/lazy-loading"], resolve)
                }
            }
        ]
    })
    
11.自定义组件

先创建一个vue的 loading 结构

loading.vue

    
    

2.在创建一个JS 文件引入这个loading.vue

index.js

    import Vue from "vue"
    import LoadingComponent from "./loading.vue"
    
    
    //extend 是构造一个组件的语法器.传入参数,返回一个组件
    let LoadingConstructor = Vue.extend(LoadingComponent);
    let initComponent;
    
    //导出 显示loading组件
    export const showLoading = (option={}) => {
        initComponent = new LoadingConstructor();
        initComponent.$mount();
        document.querySelector(option.container || "body").appendChild(initComponent.$el);
    }
    
    //导出 移除loading组件
    export const hideLoading = () => {
        initComponent.$el.parentNode.removeChild(initComponent.$el)
    }

3.最后创建一个js文件统一挂载所有自定义组件到vue原型上

output.js

    import Alert from "./alert/index.js"  //alert组件
    import { showLoading, hideLoading } from "./loading/index.js" //loading组件
    
    const install = function(Vue) { //通过install方法挂载到Vue原型上去
        Vue.prototype.$alert = Alert;
        Vue.prototype.$showLoading = showLoading;
        Vue.prototype.$hideLoading = hideLoading;
    }
    export default install

4.最后在main.js中引入 output.js

    import globalComponents from "./components/output"

    Vue.use(globalComponents);
在别的组件中通过如下直接调用就行了
    created () {
        this.$showLoading()
    
        setTimeout( () => {
            this.$hideLoading()
        }, 2000);

    }

12.路由之间的切换动画

1.用transition元素来做动画, 通过绑定name元素来切换不同的动画

    
返回

2.动画样式

    .view {
      padding: 50px 300px;
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      transition: all 0.3s linear;
    }
    .slide-left-enter,
    .slide-right-leave-active {
      opacity: 0;
      transform: translate(100%, 0);
    }
    
    .slide-left-leave-active,
    .slide-right-enter {
      opacity: 0;
      transform: translate(-100%, 0);
    }    
    

3.给路由添加返回的状态

    import Vue from "vue"
    import Router from "vue-router"
    
    Router.prototype.back = false;
    Router.prototype.goBack = function () {
          this.back = true;
          this.go(-1)
    }

4.检测路由的改变来切换状态,

    export default {
      name: "app",
        data() {
            return {
                transition: "slide-left"
            };
        },
        watch: {
            $route (to, from ) {
                var back = this.$router.back;
                if (back) { //点击了返回
                    this.transition = "slide-right"
                }else{
                    this.transition = "slide-left"
                }
                this.$router.back = false;
            }
        }
    
    }
13.生命周期的钩子函数
    beforeCreate () {
        console.log("--------------beforeCreate-------------------")
        console.log("在实例创建之后同步调用。此时实例已经结束解析选项,这意味着已建立:数据绑定,计算属性,方法,watcher/事件回")
        console.log("但是还没有开始 DOM 编译,$el 还不存在,但是实例存在")
    },
    created () {
        console.log("--------------created-------------------")
        console.log("在实例创建完成后被立即调用,挂载阶段还没开始,$el属性目前不可见")
    },
    beforeMount () {
        console.log("--------------beforeMount-------------------")
        console.log("模板编译挂载之前")
    },
    mounted () {
        console.log("--------------mounted-------------------")
        console.log("模板编译挂载之后")
    },
    beforeUpdate () {
        console.log("--------------beforeUpdate-------------------")
        console.log("组件更新之前")
    },
    updated () {
        console.log("--------------updated-------------------")
        console.log("组件更新之后")
    },
    activated () {
        console.log("--------------activated-------------------")
        console.log("keep-alive 组件激活时调用")
    },
    deactivated () {
        console.log("--------------deactivated-------------------")
        console.log("keep-alive 组件停用时调用")
    },
    beforeDestroy () {
        console.log("--------------beforeDestroy-------------------")
        console.log("组件销毁之前")
    },
    destroyed () {
        console.log("--------------destroyed-------------------")
        console.log("组件销毁之后")
    }
14. 路由钩子函数
    //全局钩子函数
    const router = new VueRouter({ ... })
    
    router.beforeEach((to, from, next) => {
        // do something  可以检测用户是否登录啥的
        next();
    });

    router.afterEach((to, from, next) => {
        console.log(to.path);
    });


    to: 即将要进入的目标 [路由对象]
    from: 当前导航正要离开的路由
    next(): 进行管道中的下一个钩子。如果全部钩子执行完了,则导航的状态就是confirmed (确认的)。
    next(false): 中断当前的导航。如果浏览器的 URL 改变了(可能是用户手动或者浏览器后退按钮),那么 URL 地址会重置到 from
    next("/") 或者 next({ path: "/" }): 跳转到一个不同的地址。当前的导航被中断,然后进行一个新的导航

   


    //组件内的钩子
    beforeRouteEnter (to, from, next) {
        // 在渲染该组件的对应路由被 confirm 前调用
        // 相对于组件来说的,而且应该是在路由进入之前开始准备的 所以beforeRouteEnter是调用ajax的时机
        // 不能获取组件实例 `this`
        // 因为当钩子执行前,组件实例还没被创建

        next();
    },

    beforeRouteLeave (to, from, next) {
        //在组件的生命周期完成后,且旧路由即将切换走,新路由beforeEach的时机执行
    }
15. 打包事项

在config 文件下的 index.js 中 修改以下属性 (如果你想在本地打包能看到页面效果, 此步骤不要忘记哦)

assetsPublicPath: "/" 

更改成

assetsPublicPath: "./" 

在构建生产环境版本时是否开启source map

    productionSourceMap: true
    

当把这个设置 置为 false 时, 文件体积会变得很小 JavaScript Source Map 详解

16. 简单文件介绍
    .babelrc

    {   
        // 此项指明,转码的规则
        "presets": [
            // env项是借助插件babel-preset-env,下面这个配置说的是babel对es6,es7,es8进行转码,并且设置amd,commonjs这样的模块化文件,不进行转码
            ["env", {
                "modules": false,
                "targets": {
                    "browsers": ["> 1%", "last 2 versions", "not ie <= 8"]
                }
            }],
            // 下面这个是不同阶段出现的es语法,包含不同的转码插件
            "stage-2"
        ],

        // 下面这个选项是引用插件来处理代码的转换,transform-runtime用来处理全局函数和优化babel编译
        "plugins": ["transform-runtime"],

        // 下面这段是在特定的环境中所执行的转码规则,当环境变量是下面的test就会覆盖上面的设置
        "env": {

            // test 是提前设置的环境变量,如果没有设置BABEL_ENV则使用NODE_ENV,如果都没有设置默认就是development
            "test": {
                "presets": ["env", "stage-2"],

                // instanbul是一个用来测试转码后代码的工具
                "plugins": ["istanbul"]  
            }
        }
    }
    .editorconfig

    charset = utf-8  //编码
    indent_style = space //缩进风格,基于空格做缩进
    indent_size = 2   //缩进大小是2格
    end_of_line = lf   //换行符的风格
    insert_final_newline = true  //当你创建一个文件,会自动在文件末尾插入新行
    trim_trailing_whitespace = true  //自动移除行尾多余空格
    package.json


      "name": "example",
      "version": "1.0.0",
      "description": "A Vue.js project",
      "author": "",
      "private": true,
      "scripts": {  
        // 例: "dev": "node build/dev-server.js"
        // "dev"就相当于需要在命令行执行 npm run dev    所有我们执行的npm run dev 相当于执行了 "node build/dev-server.js"
        // 基本所有脚本命令 都需要 加上前缀 npm run ...  ,但是 "start" 这个脚本命令只需要执行 npm start 就行,  不需要中间的 run;

        "dev": "node build/dev-server.js",
        "start": "npm run dev",
        "build": "node build/build.js"
      },
      "dependencies": {  //  生产环境所需要的依赖
        "vue": "^2.5.2",
        "vue-router": "^3.0.1"
        ......
      },
      "devDependencies": {  // 开发环境所需要的依赖
        "autoprefixer": "^7.1.2",
        "babel-core": "^6.22.1",
        .......
      },
      "engines": {
        "node": ">= 4.0.0",
        "npm": ">= 3.0.0"
      },
      "browserslist": [
        "> 1%",
        "last 2 versions",
        "not ie <= 8"
      ]
    }

更多的文件配置可以参考 vue-cli#2.0 webpack 配置分析

小结

希望能跟大家一起进步, O(∩_∩)O谢谢
github地址

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/89541.html

相关文章

  • (原创)vue 学习笔记

    摘要:菜鸟教程这是一个属性其值是字符串菜鸟教程同上这是一个属性其值是字符串用于定义的函数,可以通过来返回函数值。它们都有前缀,以便与用户定义的属性区分开来。 开篇语 我最近学习了js,取得进步,现在学习vue.js.建议新手学习,请不要用npm的方式(vue-cli,vue脚手架),太复杂了. 请直接下载vue.js文件本地引入,就上手学习吧参照菜鸟教程网站的vue.js教程http://...

    layman 评论0 收藏0
  • Vue.js学习系列二 —— vuex学习实践笔记(附DEMO)

    摘要:有兴趣的同学可以查看之前发布的文章学习系列一学习实践笔记附学习系列二学习实践笔记附学习系列三和网络传输相关知识的学习实践学习系列四打包工具的使用学习系列五从来聊聊学习系列项目地址项目暂时有点乱,之后会进行整理优化。 上次学习了vue-router的使用,让我能够在各个页面间切换,将页面搭建了起来。这次则要学习vue的状态管理模式——vuex。它类似于redux来应用的全局状态。 注:本...

    DobbyKim 评论0 收藏0
  • vue 学习笔记

    1.vue的开始 var vm = new Vue({ el: #app, // el: 用来挂载 Vue 实例的元素 data: {}, // data: 要绑定的资料 props: {}, // props: 用来接收外部资料的属性 methods: {}, ...

    yhaolpz 评论0 收藏0
  • Vue学习笔记2

    摘要:声明式渲染的引入初步使用错误笔记中的忘记大写,的忘了加引号以及忘了在末尾加逗号指令鼠标悬停几秒钟查看此处动态绑定的提示信息特性被称为指令。指令带有前缀,以表示它们是提供的特殊特性。 声明式渲染 vue的引入 初步使用vue {{message}} var app=new Vue({ el: #app, data:{ me...

    CatalpaFlat 评论0 收藏0
  • Vue学习笔记1

    摘要:声明式渲染的引入初步使用错误笔记中的忘记大写,的忘了加引号以及忘了在末尾加逗号指令鼠标悬停几秒钟查看此处动态绑定的提示信息特性被称为指令。指令带有前缀,以表示它们是提供的特殊特性。 声明式渲染 vue的引入 初步使用vue {{message}} var app=new Vue({ el: #app, data:{ me...

    winterdawn 评论0 收藏0

发表评论

0条评论

gecko23

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<