• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >JavaScript > bootstrap select插件封装成Vue2.0组件

bootstrap select插件封装成Vue2.0组件

作者:vivid_renzaijianghu 字体:[增加 减小] 来源:互联网 时间:2017-05-11

vivid_renzaijianghu通过本文主要向大家介绍了vue2.0 组件通信,vue2.0 组件,vue2.0分页组件,vue2.0 自定义组件,vue2.0父子组件通信等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

因为bootstrap-select功能比较强大,而且样式还不错,所以在项目使用了vue,所以,觉得对bootstrap-select进行封装。

html

js

// select 插件
Vue.component('vm-select', {
 props : ['options', 'value', 'multiple', 'method', 'load', 'index', 'childidx'],
 template : "<select :multiple='multiple' class='selectpicker' data-live-search='true' title='请选择' data-live-search-placeholder='搜索'><option :value='option.value' v-for='option in options'>{{ option.label }}</option></select>",
 mounted : function () {
 var vm = this;
 $(this.$el).selectpicker('val', this.value != null ? this.value : null);
 $(this.$el).on('changed.bs.select', function () {
 vm.$emit('input', $(this).val());
 if (typeof(vm.method) != 'undefined') {
 vm.method(vm.index, vm.childidx, this.value);
 }
 });
 $(this.$el).on('show.bs.select', function () {
 if (typeof(vm.load) != 'undefined') {
 vm.load(vm.index, vm.childidx);
 }
 });
 },
 updated : function () {
 $(this.$el).selectpicker('refresh');
 },
 destroyed : function () {
 $(this.$el).selectpicker('destroy');
 }
});
</div>

不得不提一下,在使用多个select的时候,在删除某一个selcet对象的时候,加载的值会发生改变,纠结了半天发现是vue自身的问题:因为vue对象有在重新渲染html的过程中会复用原来相同的vue对象,所以导致会导致selcet对象错位。解决方案:将每个select对象打上一个标签key。虽然可能导致性能的下降,但是不会导致错误。

这里写图片描述

vue官网

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • vue2.0多条件搜索组件使用详解
  • Vue2.0表单校验组件vee-validate的使用详解
  • vue基于Vue2.0和高德地图的地图组件实例
  • vue2.0父子组件间通信的实现方法
  • bootstrap select插件封装成Vue2.0组件
  • 详解vue2.0组件通信各种情况总结与实例分析
  • Vue2.0利用 v-model 实现组件props双向绑定的优美解决方案
  • 基于vue2.0+vuex的日期选择组件功能实现
  • vue2.0父子组件及非父子组件之间的通信方法

相关文章

  • 2017-05-11JS表单数据验证的正则表达式(常用)
  • 2017-05-11js放到head中失效的原因与解决方法
  • 2017-05-11bootstrap中添加额外的图标实例代码
  • 2017-05-11原生JS实现垂直手风琴效果
  • 2017-05-11JavaScript三种绑定事件方式及相互之间的区别分析
  • 2017-05-11Angular ui.bootstrap.pagination分页
  • 2017-05-11JS条形码(一维码)插件JsBarcode用法详解【编码类型、参数、属性】
  • 2017-05-11ajax异步请求详解
  • 2017-05-11JavaScript实现的选择排序算法实例分析
  • 2017-05-11JavaScript Uploadify文件上传实例

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • uploader秒传图片到服务器完整代码
    • jQuery插件HighCharts绘制2D半圆环图效果示例【附demo源码下载】
    • jQuery实现单击按钮遮罩弹出对话框效果(1)
    • 基于Marquee.js插件实现的跑马灯效果示例
    • JavaScript中双符号的运算详解
    • 微信小程序教程系列之设置标题栏和导航栏(7)
    • 超全面的JavaScript开发规范(推荐)
    • js oninput、onchange与onpropertychange事件的用法和区别
    • node.js(express)中使用Jcrop进行图片剪切上传功能
    • vue模板语法-插值详解

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有