zoukankan      html  css  js  c++  java
  • vue记事1

    1.组件引入css。

    例:test.vue引入swiper.min.css

    | -- src

    |  | -- components

    |   | -- test

    |      | -- test.vue

    | | -- css 

    |     | -- swiper.min.css

    <script>
      import '../../css/swiper.min.css';
    </script>

    组件所在处为相对位置。

    2.全局安装vue-cli

    首先确保安装node,检查node-v;.

    在node目录下输入:

    npm install - g vue-cli

    确定是否安装,输入:
    vue -V
     

    3.不要使用编辑器自带的代码格式整理

    如HBuilder
    会导致代码格式不符合规范。
    例:看起来是2个空格,实则是使用的缩进符号。
     
     

    4.请求本地数据配置

    旧版本dev-server.js ,新版本webpack.dev
     
     

    5.修改代码规范

     .eslintrc.js文件内的rules(好像没效果?)

    6.移动端设备访问

    移动端设备必须和计算机处于局域网内。

    config>>index.js文件内修改dev属性值host为本机IP地址。

    然后把网址生成二维码通过手机微信或QQ扫描。

    二维码可通过firebox或草料二维码生成

    dev: {
        host: '192.168.31.129',
    }

    7.vue-resource

    前后端数据调用.

    首先在package.json里“dependencies”引入"vue-router": "^3.0.1"

    然后npm install vue-resource

    例:使用data数据seller

    HTML调用组件,传递值

    <v-header :seller="seller"></v-header>

    js

    import header from './components/header/header'
    const ERR_OK = 0
    export default {
      name: 'App',
      data () {
        return {
          seller: {}
        }
      },
      created () {
        // vue-resourse use
        this.$http.get('/api/seller').then((response) => {
          response = response.body
          if (response.errno === ERR_OK) {
            this.seller = response.data
            console.log(this.seller)
          }
        })
      },
      components: {
        'v-header': header
      }
    }

    header组件

    HMTL

    <template>
        <div class="header">
            我是{{msg}}
          <div class="content-wrapper">
            <div class="avatar">
              <img width="64" height="64" :src="seller.avatar"/>
            </div>
            <div class="content">
              <div class="title">
                <span class="brand"></span>
                <span class="name">{{seller.name}}</span>
              </div>
              <div class="description">
                {{seller.description}}/{{seller.deliveryTime}}分钟送达
              </div>
            </div>
          </div>
        </div>
    </template>

    JS

    <script type="text/ecmascript-6">
    export default {
      name: 'header',
      data () {
        return {
          msg: 'this is header!'
        }
      },
      props: {
        seller: {
          type: ''
        }
      }
    }
    </script>

    8.stylus使用

    package.json内“devDependencies” 添加属性

    {
      "devDependencies": {
         "stylus": "^0.54.5",
         "stylus-loader": "^3.0.2",  
      }
    }    

    npm

    npm install stylus -g

    src下common内创建文件夹stylus,存放styl文件

    调用minxin.styl文件,并使用border-1px函数

    minxin.styl文件

    border-1px($color)
      position : relative
      &:after
        display: block
        position: absolute
        left: 0
        bottom: 0
        border-top 1px solid $color
         100%
        content: ' '

    引用

    <style lang="stylus" rel="stylesheet/stylus">
    @import "common/stylus/mixin.styl";
       .tab
          // border-bottom: 1px solid rgba(7, 17, 27, 0.1)
          border-1px(rgba(7, 17, 27, 0.1))
    </style>

    9.没有找到相应的模块。

    These relative modules were not found

    例:引用图标字体路径不对。

    大多都是路径的引用出了问题。

    10.过渡和v-for

    transition

    一定要使用<transition name="abc"></transition>包裹。

    使用transition="abc",方法不行

    v-for

    <div v-for="(value, key, index) in object">
      {{ index }}. {{ key }}: {{ value }}
    </div>
    new Vue({
      el: '#v-for-object',
      data: {
        object: {
          firstName: 'John',
          lastName: 'Doe',
          age: 30
        }
      }
    })

    11. this.nextTick()

    DOM更新后的回调函数,

    操作DOM在这个回调函数里比较好

    12.watch和computed属性

    compute属性可以更改data的值。要设置set属性

    computed: {
        msgChange: {
          get: function () {
            return this.msg.split('').reverse().join('')
          },
          set: function (abc) {
            this.msg = abc
          }
        }
      },

    可以使用watch监听事件来更改data属性值

    watch: {
        // 总数发生变化时,show属性值更改为false
        count: function () {
            this.show = false
        }
    },

    13.事件修饰符:stop,prevent

    .stop

    .prevent

    .capture

    .self

    .once

    .passive

    <!-- 阻止单击事件继续传播 -->
    <a v-on:click.stop="doThis"></a>
    
    <!-- 提交事件不再重载页面 -->
    <form v-on:submit.prevent="onSubmit"></form>
    
    <!-- 修饰符可以串联 -->
    <a v-on:click.stop.prevent="doThat"></a>
    
    <!-- 只有修饰符 -->
    <form v-on:submit.prevent></form>
    
    <!-- 添加事件监听器时使用事件捕获模式 -->
    <!-- 即元素自身触发的事件先在此处处理,然后才交由内部元素进行处理 -->
    <div v-on:click.capture="doThis">...</div>
    
    <!-- 只当在 event.target 是当前元素自身时触发处理函数 -->
    <!-- 即事件不是从内部元素触发的 -->
    <div v-on:click.self="doThat">...</div>

    使用修饰符时,顺序很重要;相应的代码会以同样的顺序产生。因此,用 v-on:click.prevent.self 会阻止所有的点击,而 v-on:click.self.prevent 只会阻止对元素自身的点击。

    14.父组件调用子组件的方法 ref="children"

    15.prop是单向绑定,不能更改数据的解决方案

    use a data or computed property based on the prop's value.

    https://blog.csdn.net/a_bet_of_three_years/article/details/78470757

    16.$emit,$on的使用详解

    主要介绍了vue2.0 中#$emit,$on的使用详解

    vue1.0中 vm.$dispatch 和 vm.$broadcast 被弃用,改用$emit,$on

    vm.$on( event, callback )

    监听当前实例上的自定义事件。事件可以由vm.$emit触发。回调函数会接收所有传入事件触发函数的额外参数。

    vm.$emit( event, […args] )

    触发当前实例上的事件。附加参数都会传给监听器回调。

    例子:

    //父组件
    <template>
      <ratingselect @select-type="onSelectType"></ratingselect>
    </template>
    <script>
      data () {
       return {
        selectType: 0,
      },
      methods: {
       onSelectType (type) {
        this.selectType = type
       }
      }
    </script>

    父组件使用@select-type="onSelectType"@就是v-on的简写,监听由子组件vm.$emit触发的事件,通过onSelectType()接受从子组件传递过来的数据,通知父组件数据改变了。

    // 子组件
    <template>
     <div>
      <span @click="select(0, $event)" :class="{'active': selectType===0}"></span>
      <span @click="select(1, $event)" :class="{'active': selectType===1}"></span>
      <span @click="select(2, $event)" :class="{'active': selectType===2}"></span>
     </div>
    </template>
    <script>
      data () {
       return {
        selectType: 0,
      },
      methods: {
        select (type, event) {
          this.selectType = type
          this.$emit('select-type', type)
       }
      }
    </script>

    子组件通过$emit来触发事件,将参数传递出去。

    17.缓存组件状态keep-alive

    <!-- 失活的组件将会被缓存!-->
    <keep-alive>
      <component v-bind:is="currentTabComponent"></component>
    </keep-alive>

    https://cn.vuejs.org/v2/guide/components-dynamic-async.html#%E5%9C%A8%E5%8A%A8%E6%80%81%E7%BB%84%E4%BB%B6%E4%B8%8A%E4%BD%BF%E7%94%A8-keep-alive

  • 相关阅读:
    轨迹预测-运动递归函数
    Mandelbrot集合及其渲染
    如何检测一个圆在多个圆内?
    【转】三十分钟掌握STL
    【转】如何理解c和c++的复杂类型声明
    有1,2,3一直到n的无序数组,排序
    归并排序
    希尔排序
    快速排序
    冒泡排序
  • 原文地址:https://www.cnblogs.com/miangao/p/8664782.html
Copyright © 2011-2022 走看看