资讯专栏INFORMATION COLUMN

常用的前端插件V1

xiao7cn / 2609人阅读

摘要:轻量级,功能强大的日期选择器,兼容和不依赖于其他库,少,使用作为界面的图标兼容在配置参数中,所有的类型为或的参数都可以通过属性在标签中进行设置例如月份可以滚动,年份可以手动输入是否启用日期选择是否启用秒选择器设置日期显示格

some jquery plugins are used for labelMangerSystem,some things may not be complete,ehhhh...,just leave them to perfection!
flatpickr
INTRODUCTION

轻量级(6k),功能强大的日期选择器,兼容chromefirefox

不依赖于其他库,UI少,使用SVG作为界面的图标

兼容JQuery

在配置参数中,所有的类型为string或boolean的参数都可以通过data-属性在HTML标签中进行设置,例如:data-min-date、data-default-date、data-default-date..

月份可以滚动,年份可以手动输入

CONFIG

option.enableTime

enableTime: true||false;//是否启用日期选择

option.enableSeconds

enableSeconds: true||false,//是否启用秒选择器

option.dateFormat

dataFormat: "Y-m-d"||"d.m.Y";//设置日期显示格式    

option.(minDate&maxDate)

minDate: "today"||"2016-10-20 15:30"..//可选择的最小/最大时间,与dataFormat格式一致

option.weekNumbers

weekNumbers: true||false;//是否显示周数

option.disable

disable: ["2017-03-30","2017-05-1"..]||
         [{form: "2017-04-01", to: "2017-05-01"}..]||
         [function(data){
            return (data.getMonth()%2===0)
            }]
//禁选日期,具体的值、日期范围或者函数,其余日期启用

option.enable

enable: ["2017-03-30","2017-05-1"..]||
        [{form: "2017-04-01", to: "2017-05-01"}..]||
        [function(data){
            return (data.getMonth()%2===0)
            }]
 //启用日期,其他日期禁选 

option.mode

mode: "single"||"multiple"||"range";
//分别表示只能选一个日期/可选多个日期/可选一个日期范围

option.inline

inline: true||false;//日期选择器常开或者点击触发

USAGE

在页面中引入flatpicker.css和flatpicker.js文件

解决于layer同用时,日历显示在layer层下,将 flatpicker.min.css.flatpickr-calendar.openz-index 属性值改为 9999999

① HTML


② JS

_initFlatPickr = function() {
    $("#flatpickr").flatpickr(
        //some options...
        );
}, 
jQgrid
INTRODUCTION

JQGrid是一个在jquery基础上做的一个表格控件,以ajax的方式和服务器端通信

jqGrid使用jQuery Java脚本库,并作为该包的插件编写

CONFIG

option.url 设置数据地址,直接获取数据

url: "/api/task/list-task-for-applicant",

option.datatype 数据传输格式

datatype: "json",

option.showLoadtext 读取数据或者排序时所显示的文字内容,比如loading...

showLoadtext: false,

option.showCellTips 显示单元格的提示信息,用 HTML:title 属性就行了

showCellTips: false,

option.altRows 设置为交替行表格

altRows: false,

option.colNames 表头

colNames: ["A","B","C"],

可以为表头设置样式,一般通过函数统一设置

var getHeadContent = function(arr) {
    var result = [];
    for (var i = 0, len = arr.length; i < len; i++) {
        result.push("" + arr[i] + "");
    }
    return result;
};

此时表头设置为如下所示

colNames: getHeadContent(["A","B","C"]),

option.colModel 设置 每一列 参数列表

colModel: [{
    name: "name", //设置列在表格中的唯一名称,此属性是必须的
    index: "name", //通过sidx参数设置排序时的索引名
    fixed: isFixed, //若设为true,列宽不允许重新计算。GridWidth方法改变表格宽度时,列宽也不会改变。
    width: 120, //设置列的初始宽度,可用pixels和百分比
    align: "center", //定义表格单元格(非表头)的对齐方式,可取值:left, center, right
    classes: "hello", //此属性用于定义列的类名,当有多个类名时,用空格间隔
    formatter: format4List
}]

option.rowNum 表格中可见的记录数。此参数通过url传递给服务器供检索数据用。注意:若此参数设置为10,而服务器返回15条记录,将只有10条记录被装入。若此参数被设置为-1,则此检查失效

rowNum: 7,

option.width 表格的宽度为colModel中定义的所有列宽度的总和,若设置了该项,每列的初始宽度按照shrinkToFit 设置的值

width: 1180,

option.mtype 定义提交类型POST或GET

mtype: "post",

option.pager 定义分页浏览导航条。必须是一个HTML元素

pager: "#dataPager",

option.height

height: "auto",

option.hoverrows 表行是否有鼠标悬停效果

hoverrows: false,

option.sortorder 排序规则

sortorder: "desc"||"asc",

option.viewsortcols 定义表头中排序图标的外观和行为。缺省为[false,"vertical",true]

viewsortcols: [true, "vertical", true],

event.onCellSelect 当点击单元格时触发。rowid:当前行id;iCol:当前单元格索引;cellContent:当前单元格内容;e:event对象

onCellSelect: function(rowid, iCol, cellcontent, e) {
    //coding...
}

event.loadComplete 服务器返回响应的回调函数, xhr:XMLHttpRequest 对象

loadComplete: function(xhr){
    var total = xhr.records;//表示返回的记录数
    //coding...
}

event.loadError 请求服务器失败的回调函数

loadError: function(xhr, status, error){
    //coding...
}

event.loadBeforeSend 此事件发生在XMLHttpRequest被发送前,用于修改对象属性(如headers)

loadBeforeSend: function(xhr, settings) {
    var header = JwtTool.createAuthorizationTokenHeader();
    if (header.hasOwnProperty("Authorization")) {
        xhr.setRequestHeader("Authorization", header.Authorization);
    }
}
USAGE

CSS


HTML创建一个承载表格的TABLE元素

JS




$("#taskConfigGrid").jqGrid({
    //options...
    //events...
});
requireJs
INTRODUCTION

JavaScript模块只是遵循SRP(Single Responsibility Principle单一职责原则)的代码段,传统通过

require-config.baseUrl 用于加载模块的根路径

baseUrl: "/",

require-config.paths 用来配置别名,用别名来代替模块名,注意被替代的模块名不需要.js后缀

paths: {
    //moduleID:路径(注意moduleID后缀不需要.js)
    //建议一个moduleId对应一个多带带的文件夹,因为可能因为版本不同产生差异
    "jquery": "libs/core/jquery.min"
}

require-config.shim shim配置可简单设置为依赖数组,设置shim本身不会触发代码的加载,想要实际加载shim指定的或涉及的模块,仍然需要一个常规的require/define调用

shim: {
    "jquery": {
        //加载依赖关系数组
        deps: ["css!/libs/jquery/jquery.css"]
    }
},

require-config.deps 加载依赖关系数组

deps: [
    "app"
]        

define 利用它来编写模块,然后在相应的地方进行引入

define([
    "jquery",
    "text!module/config/task-config-applicant/tpl/task-config-tpl.html"
], function(jQuery, Tpl) {
    //coding...
}

require 通过它将写好的模块进行引入,并根据这些模块编写我们的主代码

require(["jquery"], function ($) {
    //jQuery was loaded and can be used now
});
USAGE

主页面引入JS文件


配置 require.js 文件

require.config({
    urlArgs: "v=" + (new Date()).getTime(),
    waitSeconds: 0,
    baseUrl: "/",
    paths: {
        "jquery": "libs/core/jquery.min",
        "multiselect": "libs/multiselect/bootstrap-multiselect"        
        },
    shim: {
        "multiselect": {
            deps: ["css!/libs/multiselect/bootstrap-multiselect.css"]
        },
        "echarts_theme": {
            deps: ["echarts"]
        }
    },
    deps: [
        "app"
    ]
});

相应页面引入并使用

define([
    "jquery",
    "text!module/config/task-config-applicant/tpl/task-config-tpl.html"
], function(jQuery, Tpl) {
    //coding...
}
layer
INTRODUCTION

可做独立组件,一款优秀的弹出层组件

CONFIG

option.type

type:0 //信息框,默认
type:1 //页面层
type:2 //iframe层
type:3 //加载层
type:4 //tips层

option.title String/Array/Boolean,默认:"信息"

title :"我是标题"
title: ["文本", "font-size:18px;"]
title: false

option.content String/DOM/Array,默认:""

content: "传入任意的文本或html"
content: $("#id")
content: html //可以结合 HandlebarJs 使用

option.skin String 目前layer内置的skin有:layui-layer-lanlayui-layer-molv

skin: "layui-layer-rim",

option.area String/Array,默认:"auto"

area: "500px"//只定义宽度,高度自适应
area: ["500px", "300px"]

option.btn

btn: ["确定", "取消"],
btn1: function(index, layero) {
    var num = $("#submitNum").val();
    _controller.updatePassNum(v1, num).done(function(res) {
        if (res.code == 0) {
            layer.close(index);
            layer.msg("提交成功!");
            scope.refreshGrid();
        }
    });
},
btn2: function(index, layero) {
    layer.close(index);
}

option.zIndex 默认:19891014 一般用于解决和其它组件的层叠冲突

option.success

success: function(layero, index){
    console.log(layero, index);
}

layer.open

layer.open({
    option...//上述配置
});

layer.msg

layer.msg("hello",function(){
    //do something or not 
    });

layer.close 一般结合 btn 回调函数进行使用

layer.close(index)
USAGE

直接引用 layer.js 即可



handlebarsjs
INTRODUCTION

Handlebars 是JavaScript一个语义模板库,通过对 viewdata 的分离来快速构建Web模板,意义在于让你的 htmljs 充分解耦,它在加载时被预编译,而不是到了客户端执行到代码时再去编译,这样可以保证模板加载和运行的速度。

Handlebars.js 是一个由Javascript构建的编译器,它接收任意HTML与Handlebars.js表达式并将它们编译为Javascript函数。这个派生出来的Javascript函数接着接收一个参数或者一个对象(即你的数据 ),然后它返回一个包含HTML以及被插值在HTML中的对象属性值的字符串。因此,你最终可以得到一个对象属性值位于相应地方的字符串(HTML),你可以将这个字符串插入到页面中。

路径:../ 同CSS文件路径选择

Handlebar.js 模板的三个部分:

**a.** Handlebars.js表达式:{ { ... } },内容可以是变量或者函数等。 

**b.** Date(上下文):即你想要展示在页面上的内容,你将你的数据作为一个对象(一个正常的Javascript对象)传递给Handlebars函数。这个数据对象叫做上下文。这个对象能够由数组,字符串,数字,其他对象组成,或者是包含所有的东西。如果数据对象拥有一个对象数组,你可以使用Handlebars中的each辅助函数(稍后将讨论辅助函数)去迭代数组,此时的上下文将被设定为数组中的每个对象。 

**c.** handlebars编译函数:Handlebars编译函数接收模板作为参数并返回一个Javascript函数。

CONFIG

option.expression 注意HandlebarJs的标签是内闭合的,对 ifunless 只能判断 true or false, ""、undefined、null、0、[]等都会被识别为false

{ { !注释 } }

{ { content } }

{ { #if } } { { /if } }

{ { #if } } { { else } } { { /if } }

{ { #if } } { { else if } } { { else } } { { /if } }

{ { #unless } } { { /unless } } //用法同if,与if判断条件相反

{ { #each } } { { /each } } 遍历数组

{ { { richtext } } } 避免转义

Handlebar.registerHelper 自定义一个 Handlebar 函数,可在html中作为标签直接使用

//判断是否为标注管理员
Handlebars.registerHelper("isTaskManger", function(options) {
    if (_currentUserRole === "ROLE_LABEL_MANAGER") {
        //满足添加继续执行
        return options.fn(this);
    } else {
        //不满足条件执行{{else}}部分
        return options.inverse(this);
    }
});

//HTML内使用
{ { #isTaskManger } }
  • 标注任务管理
  • 提交日志管理
  • { { /isTaskManger } }

    Handlebar.compile 对 handlebars.expression 进行预编译,生成一个JavaScript函数

    var source = $("#template-user").html();//获取到html结构
    var template = Handlebars.compile(source);//编译成模板
    var html = template(data);//生成完成的html结构
    
    USAGE

    在页面中引入 Handlebar.js

    HTML内构建Handlerbar表达式

    { { #each infoList } }
    

    { { uname } }

    { { fname } }

    { { taskId } }

    { { fdesc } }

    { { machine } }

    { { update } } / {{sum}}

    { { /each } }

    JS部分:获取数据格式如下

    {
        "code": 0,
        "data": [{
            "taskId": "22000001",
            "uname": "用户1",
            "fname": "PD1",
            "fdesc": "行人检测",
            "machine": "01",
            "update": 50,
            "sum": 100
        },
        {
            "taskId": "22000002",
            "uname": "用户2",
            "fname": "PD2",
            "fdesc": "脸谱检测",
            "machine": "02",
            "update": 20,
            "sum": 100
        }
    ]
    }
    

    JS部分:对HTML进行预编译生成一个JavaScript函数,然后通过生成的函数对数据进行渲染,生成HTML

    var _getLabelInfo = function() {
        _controller.getLabelInfo().done(function(res) {
            var data = {infoList: res.data},
            template = Handlebars.compile(rightTpl)(data);
            $("#right-content").empty();
            $("#right-content").html(template);
        });
    
    };
    
    jQueryLangJs
    INTRODUCTION

    即时语言切换,无需重新加载页面或向服务器发出请求

    跨网页的语言持久性和通过cookie重新加载(需要js-cookie.js插件)

    自动翻译页面的动态部分(例如通过AJAX加载或通过jQuery添加)

    增加了对正则表达式匹配的支持

    CONFIG

    en.json 配置语言包,包含短语部分和正则部分

    {
        "token": {
            "搜索": "searchFor",
            "首页": "first",
            "尾页": "last"
        },
        "regex": [
            ["Budget", "งบประมาณ"],
            ["^Something at start of text", ""],
            ["This will be case insensitive", "i", ""]
        ]
    }
    

    option.lang 放置在 HTML 文件中,用于标记需要翻译的元素

    翻译 titlealthref

    翻译内容

    标注管理系统
    

    翻译 alert

    alert(window.lang.translate("Some text to translate"));
    

    option.data-lang-token 用于标记长文本,自定义令牌替换原文本内容

    USAGE

    JS部分

    js-cookie

    
    
    

    初始化

    var lang = new Lang();
    //初始化国际化模块
    _changeLang = function() {
        //定义语言包位置
        lang.dynamic("en", "../../libs/langpack/en.json");
        //定义默认语言
        lang.init({
            defaultLang: "cn"
        });
    },
    

    切换

    lang.change("en");
    
    
    
    
    ECharts
    INTRODUCTION

    纯javascript的图表库,支持丰富图表类型,所以下面只对项目所用的图表进行介绍

    兼容当前绝大部分浏览器(IE8/9/10/11,Chrome,Firefox,Safari等)

    底层依赖轻量级的 Canvas 类库 ZRender

    可定制,个性化

    图表父级DIV需要规定高度,否则显示不出来

    CONFIG

    option.backgroundColor

    backgroundColor: "#eee",    
    

    option.title

    title: {
            text: "主标题,
            subtext: "副标题",
            textStyle: {...},//设置标题样式
            x: "center",
            y: "top"
        },  
    

    option.tooltip

    tooltip: {
        trigger: "item",//触发类型{item/axis}
        formatter: "{a} 
    {b} : {c} ({d}%)" //提示框浮层内容格式器,支持字符串模板和回调函数两种形式,不同图表类型各个标记代表含义不同 },

    option.legend

    legend: {
        orient: "vertical",//列表的布局朝向{vertical/horizontal}
        left: "left",//自适应左边距
        data: [{
                name: "系列1",//展示数据["",...]
                icon: "circle",// 强制设置图形为圆。
                textStyle: {
                    color: "red"// 设置文本为红色
                }
                }] 
        },
    

    option.toolbox

    toolbox: {
        orient: "vertical",//工具栏 icon 的布局朝向{vertical/horizontal}
        show: true,//默认不显示
        feature: { //各工具配置项
            dataZoom: {yAxisIndex: "none"}, //区域缩放
            dataView: {readOnly: false}, //查看源数据,false时可更改
            magicType: {type: ["line", "bar"]}, //折线图和柱状图切换
            restore: {}, //刷新
            saveAsImage: {} //保存图像
        }
    },
    

    option.xAxis

    xAxis: {
        position: "top", //X轴位置,default:bottom
        name: "evsion", //X坐标轴名称
        type: "category", //坐标轴类型{value,category,time,log}
        boundaryGap: false, //坐标轴两边留白策略,类目轴和非类目轴的设置和表现不一样
        data: Array//与"category"配合使用,例["2017-4-1", "2017-4-2", "2017-4-3", "2017-4-4", "2017-4-5", "2017-4-6", "2017-4-7"]
    },
    

    option.yAxis

    yAxis: {
        type: "value",
        //坐标轴刻度的相关设置
        axisLabel: {
            formatter: "{value}~~~~"
        }
    },
    

    option.series 系列列表。每个系列通过 type 决定自己的图表类型, 每个 type 对应不同的属性

    option.radar 雷达图坐标系组件,只适用于雷达图

    indicator:  [
    { name: "销售(sales)", max: 6500},
    ... 
    ]
    

    option.visualMap

    visualMap: {
        min: 0,
        max: 10,
        calculable: true,
        orient: "horizontal",
        left: "center",
        bottom: "15%"
    },
    

    option.calendar 日历

    calendar: {
        top: "middle",
        left: "center",
        orient: "vertical",
        cellSize: [60], //单元格大小,"auto"||["20","40"]
        //是否显示年
        yearLabel: {
            show: true,
            textStyle: {
                fontSize: 30
            }
        },
        //是否显示日
        dayLabel: {
            margin: 5, //星期标签与轴线之间的距离
            firstDay: 1, //从周一开始
            nameMap: ["星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六"]
        },
        //是否显示月
        monthLabel: {
            show: true
        },
        range: ["2017-01-02", "2017-02-23"] // "2017-02"||2017||["2017-01", "2017-02"]
    },
    

    line

    series: [{
        name: "登陆量",
        type: "line",
        data: [11, 11, 15, 13, 12, 13, 10],//实际运用中用数组代替Array
        //描点
        markPoint: {
            data: [
            {
                type: "max",
                name: "最大值"
            }, {
                type: "min",
                name: "最小值"
            }]
        },
        //直线
        markLine: {
            data: [{
                type: "average",
                name: "平均值"
            }]
        }
    },
    

    pie

    series: [{
        name: "XXX",//饼图某部分激活时名称
        type: "pie",
        radius: "55%",//规定饼图大小
        center: ["50%", "60%"],
        data: [{
            //A部分的值和名称
                value: {A},
                name: category[0]
            }, {
                value: {B},
                name: category[1]
            }, {
                value: {C},
                name: category[2]
            }, {
                value: {D},
                name: category[3]
            }],
            itemStyle: {//激活时样式
                emphasis: {
                    shadowBlur: 10,
                    shadowOffsetX: 0,
                    shadowColor: "rgba(0, 0, 0, 0.5)"
                }
            }
        }]
    }; 
    

    radar

    series: [{
        name: "系统商品数量统计",
        type: "radar",
        data : [
            {
                value : gnum,
                name : "库存"
            }, {
                value : snum,
                name : "销售"
            }, {
                value : cnum,
                name : "评论"
            }
        ]
    }]
    

    map 注意ECharts3不再支持内置地图,需要到ECharts-Map按需下载

    series: [
        {   
            name: "XXX",
            type: "map",
            mapType: "湖南",//这里与配置的地图有关,注意省要用中文
            selectedMode : "multiple",//选中模式,表示是否支持多个选中,默认关闭{single/multiple}
            //图形上的文本标签,可用于说明图形的一些数据信息
            label: {
                //是否在普通状态下显示标签。
                normal: {
                    show: true
                },
                //是否在高亮状态下显示标签。
                emphasis: {
                    show: true
                }
            },
            data:[
                {name:"A", value: 100}//注意A需要与mapType里面的值相对应
            ]
        },   
     
    USAGE

    init

    var myChart = echarts.init(document.getElementById("X"));//JQuery需要($("#X")[0])
    

    config.option

    var Xoption = {
        code...//内容既为CONFIG部分
    }
    

    setOption

    myChart.setOption(Xoption);
    

    event.click
    这里params显示点击块的所有配置,然后自动跳转到百度并搜索,params.name代表点击事件触发时的取值

    myChart.on("click", function(params) {
        window.open("https://www.baidu.com/s?wd=" + encodeURIComponent(params.name));
    });
    
    pin
    INTRODUCTION

    它能将任意页面元素“钉”在某个容器顶部,而且在尺寸小的屏幕上能够自动禁用这种效果

    CONFIG

    将某元素“钉”在容器内

        $(".pinned").pin({
              containerSelector: ".container"
        })
    

    在小尺寸的屏幕上禁用Pin效果

        $(".pinned").pin({
              minWidth: 940
        })   
     
    USAGE

    直接引用 jquery.pin.js 即可

    revaelJs
    INTRODUCTION

    reveal.js是一个能够帮助我们很轻易地使用HTML来创建漂亮的PPT演示效果

    reveal.js不依赖其他任何javascript库,是一个独立的javascript插件库

    CONFIG

    options

    // 是否在右下角展示控制条
    controls: true,
    
    // 是否显示演示的进度条
    progress: true,
    
    // 是否显示当前幻灯片的页数
    slideNumber: "c/t",
    
    // 是否将每个幻灯片改变加入到浏览器的历史记录中去
    history: false,
    
    // 是否启用键盘快捷键来导航
    keyboard: true,
    
    // 是否启用幻灯片的概览模式,开启后,可以使用ESC键查看幻灯片概览
    overview: true,
    
    // 是否将幻灯片垂直居中
    center: true,
    
    // 是否在触屏设备上启用触摸导航
    touch: true,
    
    // 是否循环演示
    loop: false,
    
    // 是否将演示的方向变成 right to left
    rtl: false,
    
    // 全局开启和关闭碎片
    fragments: true,
    
    // 标识演示文稿是否在嵌入模式中运行,即包含在屏幕的有限部分中的
    embedded: false,
    
    // 标识当问号键被点击的时候是否应该显示一个帮助的覆盖层
    help: true,
    
    //  两个幻灯片之间自动切换的时间间隔(毫秒),当设置成 0 的时候则禁止自动切换,该值可以被幻灯片上的 ` data-autoslide` 属性覆盖
    autoSlide: 0,
    
    // 当遇到用户输入的时候停止切换
    autoSlideStoppable: true,
    
    // 是否启用通过鼠标滚轮来导航幻灯片
    mouseWheel: true,
    
    //  是否在移动设备上隐藏地址栏
    hideAddressBar: true,
    
    // 是否在一个弹出的 iframe 中打开幻灯片中的链接
    previewLinks: false,
    
    // 切换过渡效果
    transition: "default", // none/fade/slide/convex/concave/zoom
    
    // 过渡速度
    transitionSpeed: "default", // default/fast/slow
    
    // 全屏幻灯片背景的过渡效果
    backgroundTransition: "default", // none/fade/slide/convex/concave/zoom
    
    // 除当前可见的之外的幻灯片数量
    viewDistance: 3,
    
    // 视差背景图片
    parallaxBackgroundImage: "", // e.g. ""https://s3.amazonaws.com/hakim-static/reveal-js/reveal-parallax-1.jpg""
    
    // 视差背景尺寸
    parallaxBackgroundSize: "", // CSS syntax, e.g. "2100px 900px"
    
    // 移动视差背景(水平和垂直)滑动变化的数量, 例如100
    parallaxBackgroundHorizontal: "",
    parallaxBackgroundVertical: ""
    

    options.transition None - Fade - Slide - Convex - Concave - Zoom

    options.theme Black (default) - White - League - Sky - Beige - SimpleSerif - Blood - Night - Moon - Solarized

    
    

    options.background #color||image.png(data-background-repeat="repeat" data-background-size="100px)||

    option.data-background-video

    keyboard

    B||.  //pause
    o   //preview
    F11 // full screen                
    
    USAGE

    CSS

    
    
    

    HTML

    Reveal.js

    HELLO WORLD!

    JS

    
    //初始化
    Reveal.initialize({
        //options...    
    })
    
    material-icon
    INTRODUCTION

    大方,美观,跨平台,易于使用

    CONFIG

    CSS配置,可根据需求自行调节样式

    @font-face {
        font-family: "Material Icons";
        font-style: normal;
        font-weight: 400;
        src: local("Material Icons"), local("MaterialIcons-Regular"), url(http://fonts.gstatic.com/s/materialicons/v21/2fcrYFNaTjcS6g4U3t-Y5ZjZjT5FdEJ140U2DJYC3mY.woff2) format("woff2");
    }
    
    .material-icons {
        font-family: "Material Icons";
        font-weight: normal;
        font-style: normal;
        font-size: 24px;
        line-height: 1;
        letter-spacing: normal;
        text-transform: none;
        display: inline-block;
        white-space: nowrap;
        word-wrap: normal;
        direction: ltr;
        -webkit-font-feature-settings: "liga";
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
    }
    
    USAGE

    配置CSS文件即可

    DEMO

    event
    
    Bootstrap Multiselect
    INTRODUCTION

    Bootstrap Multiselect 是一个基于JQuery的插件,用于提供直观的用户界面,用于使用具有多个属性的选择输入。

    CONFIG

    option.multiple 添加在

    option.maxHeight 下拉框最大高度

    maxHeight: 300
    

    option.buttonWidth 触发按钮宽度

    buttonWidth: "400px"
    

    option.includeSelectAllOption 全选

    includeSelectAllOption: true
    

    option.enableFiltering 启用筛选

    enableFiltering: true
    
    USAGE

    引入 JSCSS 文件,在CSS文件内进行相关样式的更改

    
    
    
    
    
    

    创建一个下拉选择框

    
    

    初始化插件

    
    

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

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

    相关文章

    • 前端(HTML css JS)开发工具及常用插件推荐

      摘要:前端编程工具有很多,例如简称,,,,等等,今天给大家推荐的是是一个完全免费的软件,页面简介大方,是前端开发者最受欢迎的软件之一。 前端编程工具有很多,例如Visua...

      betacat 评论0 收藏0
    • 微店前端工程化迭代史

      摘要:文章同步在微店前端工程化起步于一个内部产品,对外我们有一个开源版本。这么长时间过去了,我们在前端工程化方面有了哪些变化遇到了哪些问题用怎样的方案解决这些问题等等,值得为大家再分享。最终产品以命令行的形式发布。 文章同步在:https://github.com/hoperyy/bl... 微店前端工程化起步于一个内部产品 vbuilder,对外我们有一个开源版本 bio-cli。 去年我...

      littlelightss 评论0 收藏0
    • eyoucms v1.4.9授权破解版 易优cms企业建站系统去版权版 v1.4.9

      摘要:授权破解版易优企业建站系统易优企业建站系统是一款十分优秀专业的为企业创建网站服务的软件。去版权破解版强大好用,为企业创建网站提供很多帮助和便利。直接去易优官网,购买商业授权即可去除版权。eyoucms v1.4.9授权破解版(易优企业建站系统)是一款十分优秀专业的为企业创建网站服务的软件。eyoucms v1.4.9去版权破解版 强大好用,为企业创建网站提供很多帮助和便利。易优cms破解授权...

      番茄西红柿 评论0 收藏2637
    • 2016年最具潜力前端开源项目Top20

      摘要:作为年最具潜力,乃至最具影响力的前端开源项目真的不为过。通过上的介绍,这个项目是偏右阿里的前端大牛和阿里的前端大牛主导,而且从中也不难看出有些部分是来自参与过的项目。 showImg(https://segmentfault.com/img/bVH8b2?w=900&h=500); 在2016年,前端的开源世界越发精彩,Vue的不断壮大,Angular 2的发布,Amaze UI 3....

      winterdawn 评论0 收藏0
    • 2016年最具潜力前端开源项目Top20

      摘要:作为年最具潜力,乃至最具影响力的前端开源项目真的不为过。通过上的介绍,这个项目是偏右阿里的前端大牛和阿里的前端大牛主导,而且从中也不难看出有些部分是来自参与过的项目。 showImg(https://segmentfault.com/img/bVH8b2?w=900&h=500); 在2016年,前端的开源世界越发精彩,Vue的不断壮大,Angular 2的发布,Amaze UI 3....

      xiguadada 评论0 收藏0

    发表评论

    0条评论

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