当前位置 主页 > 网站技术 > 代码类 >

    Vue数字输入框组件的使用方法

    栏目:代码类 时间:2019-10-19 12:09

    最近在通过《Vue.js实战》系统学习Vue,虽然在项目中已多次使用Vue进行开发,但是对于一些非常基础性的知识点还不是很了解,因此这次通过结合数字输入框组件实战来谈谈简单的组件开发。

    源代码:数字输入框组件

    项目整体结构

    ├── src  项目代码
    │ ├── common 公共js库
    │ │ ├── number.js 判断是否为数字
    │ ├── components 组件
    │ │ ├── inputCount.vue 数字输入框组件
    │ │ ├── inputNumber.vue 数字输入框调用页
    | ├── router 路由
    | | ├── index.js 路由相关操作
    | ├── App.vue 入口页
    | ├── main.js !Webpack配置约定的js入口,不要修改名称和路径

    main.js

    入口文件,主要作用是初始化vue实例并使用需要的插件

    import Vue from 'vue'
    import App from './App'
    import router from './router'
    
    Vue.config.productionTip = false
    
    /* eslint-disable no-new */
    new Vue({
     el: '#app',
     router,
     components: { App },
     template: '<App/>'
    })

    App.vue

    主组件,所有页面都是在App.vue下进行切换的。所有的路由也是App.vue的子组件

    <template>
     <div >
      <router-view/>
     </div>
    </template>
    
    <script>
    export default {
     name: 'App'
    }
    </script>

    router/index.js

    // import引入路由组件
    import Vue from 'vue'
    import Router from 'vue-router'
    import inputNumber from '@/components/inputNumber'
    Vue.use(Router)
    // 然后定义路由(routes),并创建路由实例
    export default new Router({
     routes: [
      {
       path: '/',
       name: 'index',
       component: inputNumber
      }
     ]
    })

    common/number.js

    // 判断输入的值是否为数字
    function isValueNumber (value) {
     var reg = /^[0-9]+.?[0-9]*$/
     if (reg.test(value)) {
      return true
     }
     return false
    }
    // 切记将此函数暴露,否则无法调用
    export {
     isValueNumber
    }

    components/inputNumber.vue

    <template>
     <div>
       // 双向绑定value,并设默认值为5,最大值为100,最小值为0
       <input-count v-model="value" :max="100" :min="0"></input-count>
     </div>
    </template>
    
    <script>
    //引入子组件
    import inputCount from '../components/inputCount'
    export default {
     data () {
      return {
       value: 5 //设置初始值为5
      }
     },
    
     components: {
      inputCount
     }
    }
    </script>

    components/inputCount.vue

    <template>
     <div class="input-number">
      <input type="text" :value="currentValue" @change="handleChange" @keyup.down="handleDown" @keyup.up="handleUp"/>
      <button @click="handleDown" :disabled="currentValue <= min" >-</button>
      <button @click="handleUp" :disabled="currentValue >= max">+</button>
     </div>
    </template>

    input绑定了currentValue和原生的change事件,在句柄handleChagne函数中,因为绑定的currentValue是单向数据流,所以在输入时,currentValue的值并没有实时进行改变。如果输入的不是数字,就将输入的内容重置为之前的currentValue;如果输入的值是数字,就把输入的值赋给currentValue。