• vue笔记


    一、部署

    需要nodejs,全局安装 npm install -g vue-cli ,项目目录执行  vue init webpack firstVue,自己选取ide,推荐westorm/vscode/sublime text其中一个。本地运行执行npm run dev,这里注意本机环境需要有安装过nodejs环境,运行完后在默认浏览器打开一个localhost:8080

    二、更改启动页

    更改默认启动页显示内容方式有两种。首先必须说明一下框架默认只有一个html文件,也就是根目录index.html。

    1)在根目录下找到src/router-map.js文件,找到启动页配置/,如果要改动默认第一页显示的内容,更改/里面默认显示的vue文件名。

    格式参考:

    '/': {

       name: 'index',

       component(resolve){

       require(['./components/Index.vue'], resolve)

       }

    },'/home': {

       name: 'home',

       component(resolve){

       require(['./components/Home.vue'], resolve)

       }

    }

    2) 在根目录下找到src/main.js文件,在router.start(App, '#app')这句后面可以加上一些js逻辑判断,跳转显示哪个为第一页。

    参考格式:

    router.go({

       name: 'home'

    })

    三、新增页面

    新增页面,也就是新增一个vue文件。在根目录下找到src/components新增一个xx.vue文件。根节点template下只能有一个子节点,不允许多个子节点。

    参考格式:

    <template>

        <div>

    <div>

           </div>

        <div>

           </div>

        </div>

    </template>

     

    <script>

        export default{

            data(){

                return {

                    //这里设置当前页面的基础变量数据

                    msg: 'hello vue'

                }

            },

            ready: function(){

    //这里可以用data的默认数据更改、初始化、绑定事件

            },

            methods: {

                //事件方法都写在这里

                goTo: function(url){

                    this.$router.go({name: url});

                }

            },

            components: {

               //这里是组件,例如你引入Toast,需要在这里注入。

            }

        }

    </script>

    <style lang="less" scoped>

        @import '../styles/home.less';

    </style>

    四、新增样式

    新增样式有两种方式,一是直接在vue文件内部,二是引入外部文件。具有 scoped 属性的样式只会应用到当前元素和其子元素。另外需要注意lang,默认不写lang是平常普通的css。

    内部方式:

    <style lang="less" scoped>

    .ok {

       opacity: 1;

        }

    </style>

    外部方式:

    <style lang="less" scoped>

        @import '../styles/home.less';

    </style>

    五、组件使用

    引入组件,这个举例一个提示组件toast。有3个地方需要注意。

    1)引入toast组件的js文件

    参考格式:

    <script>

       import Scroller from 'vux/src/components/toast';

    </script>

    2)引入toast组件的样式文件

    参考格式:

      <style scoped>

    @import '../../node_modules/vux/dist/components/toast/style.css';

    </style>

    3)注入toast文件

    参考格式

      components: {

         Toast

    }

    具体说明或其它组件请参照网站说明:https://vuxjs.gitbooks.io/vux/content/

    六、第三方库文件

    引入外部库文件,用npm管理依赖,例如想引入swiper或者jquery

    在根目录下cmd终端下执行npm install swiper –save,安装在项目里面的node_modules 目录,package.json 也会更新,然后用import引入进来。

    引入方式可参考引入组件方式。

    七、路由问题

    路由问题,例如我需要在跳转的时候把id带过去另外一个页面。首先要在router-map.js文件上标明跳转的时候我必须要带上id这个key。

    参考格式:

       '/caseDetail/:id': {

    name: 'caseDetail',

    component(resolve){

    require(['./components/CaseDetail.vue'], resolve)

    }

    }

    dom操作方式

    <div v-link="{name: 'caseList', params: { id: 123 }}"></div>

    js操作方式

    this.$router.go({ name: 'caseDetail', params: { id: id } });

    如果需要关注router变化做操作,需要在这里去做逻辑处理

    参考格式:

    route: {

        data() {

          // console.log("============:"+this.$route);

          this.moduleId = this.$route.params.id;

          this.getDetailInfo(this.moduleId);

          }

    }

    八、接口问题

    接口问题,首先需要在根目录下的src/services/services.js声明

    参考格式:

    import Vue from 'vue'

    const HOLIKE_REMOTE = 'http://qj.holike.com'

    export default {

    Vue.resource(`${HTTP_REMOTE}/hlkapp/hlk/projectHouse/updateipad`)

    }

       然后在vue引入services

       import services from '../services/services';

       注意是get请求还是post请求

       get请求,参考格式:

       var requestBody = {};

       requestBody.name = this.accountVal; 

       services.login.get(requestBody).then((res) => {

          var data = res.body;

          if (data.code == 200) {

              console.log(JSON.stringify(returnData));

          }

       }, (error) => {

          console.log("error:" + error);

       });

       post请求,参考格式:

       var requestBody = {};

       requestBody.name = this.accountVal; 

       services.login.save(requestBody).then((res) => {

          var data = res.body;

          if (data.code == 200) {

              console.log(JSON.stringify(returnData));

          }

       }, (error) => {

          console.log("error:" + error);

       });

    九、接口拦截器

    增加接口拦截器,在根目录下找到src/main.js文件,可以在router.map(routerMap)后面加上interceptors

    参考格式:

    Vue.http.interceptors.push((request, next) => {

    //这里是接口请求前做的操作

        Vue.http.headers.common['USER-TOKEN'] = 'fofofo'

        next((response) => {

    //这里是接口请求后返回数据做的操作

            console.log('response====', response.body)

            if (response.body.code === -2) {

                router.go({

                    name: 'index'

                })

            }

        })

    })

    十、路径问题

    路径问题,例如我在根目录static添加了一个images放图片文件。如果是在dom里面写可以是<img src="../../static/images/brand-baby-leftBg.png" />,如果是在js里写,需要写成./static/images/alpes-zone-zw2.jpg这种方式。这里注意如果有本地视频,在dom里也要写成是./static/video/baby_video2.mp4这种方式

    十一、vuex使用

    例如我有个toast想作为整个项目来使用,那就不需要在每个页面vue中分别引入toast组件。

    1)根目录下的App.vue文件

    参考格式

    <template>

      <div>

         <toast :show="toastShown" type="text" width="20em" @on-hide="toastOnChange">{{toastText}}</toast>

      </div>

    </template>

    <script>

        import Toast from 'vux/dist/components/toast/index.js';

        import store from './vuex/store'

        let commit = store.commit || store.dispatch

        export default {

            methods: {

                toastOnChange() {

                    commit('UPDATE_TOAST', '', false)

                }

            },

            components: {

                Toast

            },

            store,

            vuex: {

                getters: {

                    toastShown: state => state.toastShown,

                    toastText: state => state.toastText,

                    route: state => state.route,

                    isLoading: state => state.isLoading,

                    direction: state => state.direction

                }

            }

        }

    2)根目录下的vuex/store.js

    const state = {

        isLoading: false,

        toastText:''

    }

    export default new Vuex.Store({

        state,

        mutations: {

            

            UPDATE_TOAST (state, text, bool) {

                state.toastText = text

                state.toastShown = bool

            }

        }

    })

    3)在需要显示toast的地方传入显示文本和标志符,例如commit('UPDATE_TOAST', '请重新登录', true)

    十二、cordova联调

    为了全局可以使用cordova,必须先在index.html上引入cordova,例如<script src="cordova.js"></script>

    参考格式:

    cordova.plugins.NetworkUtil.isNetworkAvailable((flag) => {

       console.log('NetworkUtil.isNetworkAvailable success:' + flag);

       if (flag) {

           

       } else {

          

       }

       }, (error) => {

          console.log('NetworkUtil.isNetworkAvailable error:' + error);

    });

  • 相关阅读:
    gdb调试core文件
    设计模式之工厂模式
    设计模式之简单工厂模式
    正确理解python的装饰器
    深入理解MVC架构
    django的模板系统过滤器笔记
    python net-snmp 的使用
    用django写个CMS系统
    django的CMS系统(内容管理系统)
    RESTful 的通俗解释
  • 原文地址:https://www.cnblogs.com/web-dev-engineer/p/6362797.html
Copyright © 2020-2023  润新知