摘要:輕量級(jí),功能強(qiáng)大的日期選擇器,兼容和不依賴于其他庫(kù),少,使用作為界面的圖標(biāo)兼容在配置參數(shù)中,所有的類型為或的參數(shù)都可以通過(guò)屬性在標(biāo)簽中進(jìn)行設(shè)置例如月份可以滾動(dòng),年份可以手動(dòng)輸入是否啟用日期選擇是否啟用秒選擇器設(shè)置日期顯示格
some jquery plugins are used for labelMangerSystem,some things may not be complete,ehhhh...,just leave them to perfection!flatpickr
輕量級(jí)(6k),功能強(qiáng)大的日期選擇器,兼容chrome和firefox
不依賴于其他庫(kù),UI少,使用SVG作為界面的圖標(biāo)
兼容JQuery
在配置參數(shù)中,所有的類型為string或boolean的參數(shù)都可以通過(guò)data-屬性在HTML標(biāo)簽中進(jìn)行設(shè)置,例如:data-min-date、data-default-date、data-default-date..
月份可以滾動(dòng),年份可以手動(dòng)輸入
option.enableTime
enableTime: true||false;//是否啟用日期選擇
option.enableSeconds
enableSeconds: true||false,//是否啟用秒選擇器
option.dateFormat
dataFormat: "Y-m-d"||"d.m.Y";//設(shè)置日期顯示格式
option.(minDate&maxDate)
minDate: "today"||"2016-10-20 15:30"..//可選擇的最小/最大時(shí)間,與dataFormat格式一致
option.weekNumbers
weekNumbers: true||false;//是否顯示周數(shù)
option.disable
disable: ["2017-03-30","2017-05-1"..]|| [{form: "2017-04-01", to: "2017-05-01"}..]|| [function(data){ return (data.getMonth()%2===0) }] //禁選日期,具體的值、日期范圍或者函數(shù),其余日期啟用
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"; //分別表示只能選一個(gè)日期/可選多個(gè)日期/可選一個(gè)日期范圍
option.inline
inline: true||false;//日期選擇器常開或者點(diǎn)擊觸發(fā)
在頁(yè)面中引入flatpicker.css和flatpicker.js文件
解決于layer同用時(shí),日歷顯示在layer層下,將 flatpicker.min.css 內(nèi) .flatpickr-calendar.open 的 z-index 屬性值改為 9999999
① HTML
② JS
_initFlatPickr = function() { $("#flatpickr").flatpickr( //some options... ); },jQgrid
JQGrid是一個(gè)在jquery基礎(chǔ)上做的一個(gè)表格控件,以ajax的方式和服務(wù)器端通信
jqGrid使用jQuery Java腳本庫(kù),并作為該包的插件編寫
option.url 設(shè)置數(shù)據(jù)地址,直接獲取數(shù)據(jù)
url: "/api/task/list-task-for-applicant",
option.datatype 數(shù)據(jù)傳輸格式
datatype: "json",
option.showLoadtext 讀取數(shù)據(jù)或者排序時(shí)所顯示的文字內(nèi)容,比如loading...
showLoadtext: false,
option.showCellTips 顯示單元格的提示信息,用 HTML:title 屬性就行了
showCellTips: false,
option.altRows 設(shè)置為交替行表格
altRows: false,
option.colNames 表頭
colNames: ["A","B","C"],
可以為表頭設(shè)置樣式,一般通過(guò)函數(shù)統(tǒng)一設(shè)置
var getHeadContent = function(arr) {
var result = [];
for (var i = 0, len = arr.length; i < len; i++) {
result.push("" + arr[i] + "");
}
return result;
};
此時(shí)表頭設(shè)置為如下所示
colNames: getHeadContent(["A","B","C"]),
option.colModel 設(shè)置 每一列 參數(shù)列表
colModel: [{ name: "name", //設(shè)置列在表格中的唯一名稱,此屬性是必須的 index: "name", //通過(guò)sidx參數(shù)設(shè)置排序時(shí)的索引名 fixed: isFixed, //若設(shè)為true,列寬不允許重新計(jì)算。GridWidth方法改變表格寬度時(shí),列寬也不會(huì)改變。 width: 120, //設(shè)置列的初始寬度,可用pixels和百分比 align: "center", //定義表格單元格(非表頭)的對(duì)齊方式,可取值:left, center, right classes: "hello", //此屬性用于定義列的類名,當(dāng)有多個(gè)類名時(shí),用空格間隔 formatter: format4List }]
option.rowNum 表格中可見的記錄數(shù)。此參數(shù)通過(guò)url傳遞給服務(wù)器供檢索數(shù)據(jù)用。注意:若此參數(shù)設(shè)置為10,而服務(wù)器返回15條記錄,將只有10條記錄被裝入。若此參數(shù)被設(shè)置為-1,則此檢查失效
rowNum: 7,
option.width 表格的寬度為colModel中定義的所有列寬度的總和,若設(shè)置了該項(xiàng),每列的初始寬度按照shrinkToFit 設(shè)置的值
width: 1180,
option.mtype 定義提交類型POST或GET
mtype: "post",
option.pager 定義分頁(yè)瀏覽導(dǎo)航條。必須是一個(gè)HTML元素
pager: "#dataPager",
option.height
height: "auto",
option.hoverrows 表行是否有鼠標(biāo)懸停效果
hoverrows: false,
option.sortorder 排序規(guī)則
sortorder: "desc"||"asc",
option.viewsortcols 定義表頭中排序圖標(biāo)的外觀和行為。缺省為[false,"vertical",true]
viewsortcols: [true, "vertical", true],
event.onCellSelect 當(dāng)點(diǎn)擊單元格時(shí)觸發(fā)。rowid:當(dāng)前行id;iCol:當(dāng)前單元格索引;cellContent:當(dāng)前單元格內(nèi)容;e:event對(duì)象
onCellSelect: function(rowid, iCol, cellcontent, e) { //coding... }
event.loadComplete 服務(wù)器返回響應(yīng)的回調(diào)函數(shù), xhr:XMLHttpRequest 對(duì)象
loadComplete: function(xhr){ var total = xhr.records;//表示返回的記錄數(shù) //coding... }
event.loadError 請(qǐng)求服務(wù)器失敗的回調(diào)函數(shù)
loadError: function(xhr, status, error){ //coding... }
event.loadBeforeSend 此事件發(fā)生在XMLHttpRequest被發(fā)送前,用于修改對(duì)象屬性(如headers)
loadBeforeSend: function(xhr, settings) { var header = JwtTool.createAuthorizationTokenHeader(); if (header.hasOwnProperty("Authorization")) { xhr.setRequestHeader("Authorization", header.Authorization); } }
CSS
HTML創(chuàng)建一個(gè)承載表格的TABLE元素
JS
$("#taskConfigGrid").jqGrid({ //options... //events... });requireJs
JavaScript模塊只是遵循SRP(Single Responsibility Principle單一職責(zé)原則)的代碼段,傳統(tǒng)通過(guò) 標(biāo)簽來(lái)進(jìn)行加載,這就需要持續(xù)不斷的關(guān)注模塊之間的依賴性,按照一個(gè)特定的順序加載這些模塊,否則運(yùn)行時(shí)將會(huì)發(fā)生錯(cuò)誤(這種錯(cuò)誤我經(jīng)常遇到)
AMD(異步模塊定義)就是這樣一種對(duì)模塊的定義,使模塊和它的依賴可以被異步的加載,但又按照正確的順序
RequireJS是一個(gè)Javascript 文件和模塊框架,使用RequireJS,你可以順序讀取僅需要相關(guān)依賴模塊。RequireJS所做的是,在你使用script標(biāo)簽加載你所定義的依賴時(shí),將這些依賴通過(guò)head.appendChild()函數(shù)來(lái)加載他們。
當(dāng)依賴加載以后,RequireJS計(jì)算出模塊定義的順序,并按正確的順序進(jìn)行調(diào)用。這意味著你需要做的僅僅是使用一個(gè)“根”來(lái)讀取你需要的所有功能,然后剩下的事情只需要交給RequireJS就行了。
option.data-main 用來(lái)引入 入口文件(當(dāng)requireJS被加載完成后立即調(diào)用的文件稱為入口文件)
require-config.baseUrl 用于加載模塊的根路徑
baseUrl: "/",
require-config.paths 用來(lái)配置別名,用別名來(lái)代替模塊名,注意被替代的模塊名不需要.js后綴
paths: { //moduleID:路徑(注意moduleID后綴不需要.js) //建議一個(gè)moduleId對(duì)應(yīng)一個(gè)多帶帶的文件夾,因?yàn)榭赡芤驗(yàn)榘姹静煌a(chǎn)生差異 "jquery": "libs/core/jquery.min" }
require-config.shim shim配置可簡(jiǎn)單設(shè)置為依賴數(shù)組,設(shè)置shim本身不會(huì)觸發(fā)代碼的加載,想要實(shí)際加載shim指定的或涉及的模塊,仍然需要一個(gè)常規(guī)的require/define調(diào)用
shim: { "jquery": { //加載依賴關(guān)系數(shù)組 deps: ["css!/libs/jquery/jquery.css"] } },
require-config.deps 加載依賴關(guān)系數(shù)組
deps: [ "app" ]
define 利用它來(lái)編寫模塊,然后在相應(yīng)的地方進(jìn)行引入
define([ "jquery", "text!module/config/task-config-applicant/tpl/task-config-tpl.html" ], function(jQuery, Tpl) { //coding... }
require 通過(guò)它將寫好的模塊進(jìn)行引入,并根據(jù)這些模塊編寫我們的主代碼
require(["jquery"], function ($) { //jQuery was loaded and can be used now });
主頁(yè)面引入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" ] });
相應(yīng)頁(yè)面引入并使用
define([ "jquery", "text!module/config/task-config-applicant/tpl/task-config-tpl.html" ], function(jQuery, Tpl) { //coding... }layer
可做獨(dú)立組件,一款優(yōu)秀的彈出層組件
option.type
type:0 //信息框,默認(rèn) type:1 //頁(yè)面層 type:2 //iframe層 type:3 //加載層 type:4 //tips層
option.title String/Array/Boolean,默認(rèn):"信息"
title :"我是標(biāo)題" title: ["文本", "font-size:18px;"] title: false
option.content String/DOM/Array,默認(rèn):""
content: "傳入任意的文本或html" content: $("#id") content: html //可以結(jié)合 HandlebarJs 使用
option.skin String 目前l(fā)ayer內(nèi)置的skin有:layui-layer-lanlayui-layer-molv
skin: "layui-layer-rim",
option.area String/Array,默認(rèn):"auto"
area: "500px"http://只定義寬度,高度自適應(yīng) 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 默認(rèn):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 一般結(jié)合 btn 回調(diào)函數(shù)進(jìn)行使用
layer.close(index)
直接引用 layer.js 即可
handlebarsjs
Handlebars 是JavaScript一個(gè)語(yǔ)義模板庫(kù),通過(guò)對(duì) view 和 data 的分離來(lái)快速構(gòu)建Web模板,意義在于讓你的 html 和 js 充分解耦,它在加載時(shí)被預(yù)編譯,而不是到了客戶端執(zhí)行到代碼時(shí)再去編譯,這樣可以保證模板加載和運(yùn)行的速度。
Handlebars.js 是一個(gè)由Javascript構(gòu)建的編譯器,它接收任意HTML與Handlebars.js表達(dá)式并將它們編譯為Javascript函數(shù)。這個(gè)派生出來(lái)的Javascript函數(shù)接著接收一個(gè)參數(shù)或者一個(gè)對(duì)象(即你的數(shù)據(jù) ),然后它返回一個(gè)包含HTML以及被插值在HTML中的對(duì)象屬性值的字符串。因此,你最終可以得到一個(gè)對(duì)象屬性值位于相應(yīng)地方的字符串(HTML),你可以將這個(gè)字符串插入到頁(yè)面中。
路徑:../ 同CSS文件路徑選擇
Handlebar.js 模板的三個(gè)部分:
**a.** Handlebars.js表達(dá)式:{ { ... } },內(nèi)容可以是變量或者函數(shù)等。 **b.** Date(上下文):即你想要展示在頁(yè)面上的內(nèi)容,你將你的數(shù)據(jù)作為一個(gè)對(duì)象(一個(gè)正常的Javascript對(duì)象)傳遞給Handlebars函數(shù)。這個(gè)數(shù)據(jù)對(duì)象叫做上下文。這個(gè)對(duì)象能夠由數(shù)組,字符串,數(shù)字,其他對(duì)象組成,或者是包含所有的東西。如果數(shù)據(jù)對(duì)象擁有一個(gè)對(duì)象數(shù)組,你可以使用Handlebars中的each輔助函數(shù)(稍后將討論輔助函數(shù))去迭代數(shù)組,此時(shí)的上下文將被設(shè)定為數(shù)組中的每個(gè)對(duì)象。 **c.** handlebars編譯函數(shù):Handlebars編譯函數(shù)接收模板作為參數(shù)并返回一個(gè)Javascript函數(shù)。
option.expression 注意HandlebarJs的標(biāo)簽是內(nèi)閉合的,對(duì) if 和 unless 只能判斷 true or false, ""、undefined、null、0、[]等都會(huì)被識(shí)別為false
{ { !注釋 } } { { content } } { { #if } } { { /if } } { { #if } } { { else } } { { /if } } { { #if } } { { else if } } { { else } } { { /if } } { { #unless } } { { /unless } } //用法同if,與if判斷條件相反 { { #each } } { { /each } } 遍歷數(shù)組 { { { richtext } } } 避免轉(zhuǎn)義
Handlebar.registerHelper 自定義一個(gè) Handlebar 函數(shù),可在html中作為標(biāo)簽直接使用
//判斷是否為標(biāo)注管理員 Handlebars.registerHelper("isTaskManger", function(options) { if (_currentUserRole === "ROLE_LABEL_MANAGER") { //滿足添加繼續(xù)執(zhí)行 return options.fn(this); } else { //不滿足條件執(zhí)行{{else}}部分 return options.inverse(this); } }); //HTML內(nèi)使用 { { #isTaskManger } }
Handlebar.compile 對(duì) handlebars.expression 進(jìn)行預(yù)編譯,生成一個(gè)JavaScript函數(shù)
var source = $("#template-user").html();//獲取到html結(jié)構(gòu) var template = Handlebars.compile(source);//編譯成模板 var html = template(data);//生成完成的html結(jié)構(gòu)
在頁(yè)面中引入 Handlebar.js
HTML內(nèi)構(gòu)建Handlerbar表達(dá)式
{ { #each infoList } }{ { /each } }{ { uname } }
{ { fname } }
{ { taskId } }
{ { fdesc } }
{ { machine } }
{ { update } } / {{sum}}
JS部分:獲取數(shù)據(jù)格式如下
{ "code": 0, "data": [{ "taskId": "22000001", "uname": "用戶1", "fname": "PD1", "fdesc": "行人檢測(cè)", "machine": "01", "update": 50, "sum": 100 }, { "taskId": "22000002", "uname": "用戶2", "fname": "PD2", "fdesc": "臉譜檢測(cè)", "machine": "02", "update": 20, "sum": 100 } ] }
JS部分:對(duì)HTML進(jìn)行預(yù)編譯生成一個(gè)JavaScript函數(shù),然后通過(guò)生成的函數(shù)對(duì)數(shù)據(jù)進(jìn)行渲染,生成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
即時(shí)語(yǔ)言切換,無(wú)需重新加載頁(yè)面或向服務(wù)器發(fā)出請(qǐng)求
跨網(wǎng)頁(yè)的語(yǔ)言持久性和通過(guò)cookie重新加載(需要js-cookie.js插件)
自動(dòng)翻譯頁(yè)面的動(dòng)態(tài)部分(例如通過(guò)AJAX加載或通過(guò)jQuery添加)
增加了對(duì)正則表達(dá)式匹配的支持
en.json 配置語(yǔ)言包,包含短語(yǔ)部分和正則部分
{ "token": { "搜索": "searchFor", "首頁(yè)": "first", "尾頁(yè)": "last" }, "regex": [ ["Budget", "????????"], ["^Something at start of text", ""], ["This will be case insensitive", "i", ""] ] }
option.lang 放置在 HTML 文件中,用于標(biāo)記需要翻譯的元素
翻譯 title、alt、href
翻譯內(nèi)容
標(biāo)注管理系統(tǒng)
翻譯 alert
alert(window.lang.translate("Some text to translate"));
option.data-lang-token 用于標(biāo)記長(zhǎng)文本,自定義令牌替換原文本內(nèi)容
JS部分
js-cookie
初始化
var lang = new Lang(); //初始化國(guó)際化模塊 _changeLang = function() { //定義語(yǔ)言包位置 lang.dynamic("en", "../../libs/langpack/en.json"); //定義默認(rèn)語(yǔ)言 lang.init({ defaultLang: "cn" }); },
切換
lang.change("en");ECharts
純javascript的圖表庫(kù),支持豐富圖表類型,所以下面只對(duì)項(xiàng)目所用的圖表進(jìn)行介紹
兼容當(dāng)前絕大部分瀏覽器(IE8/9/10/11,Chrome,F(xiàn)irefox,Safari等)
底層依賴輕量級(jí)的 Canvas 類庫(kù) ZRender
可定制,個(gè)性化
圖表父級(jí)DIV需要規(guī)定高度,否則顯示不出來(lái)
option.backgroundColor
backgroundColor: "#eee",
option.title
title: { text: "主標(biāo)題, subtext: "副標(biāo)題", textStyle: {...},//設(shè)置標(biāo)題樣式 x: "center", y: "top" },
option.tooltip
tooltip: { trigger: "item",//觸發(fā)類型{item/axis} formatter: "{a}
: {c} (qoyqs8suu2u%)" //提示框浮層內(nèi)容格式器,支持字符串模板和回調(diào)函數(shù)兩種形式,不同圖表類型各個(gè)標(biāo)記代表含義不同 },
option.legend
legend: { orient: "vertical",//列表的布局朝向{vertical/horizontal} left: "left",//自適應(yīng)左邊距 data: [{ name: "系列1",//展示數(shù)據(jù)["",...] icon: "circle",// 強(qiáng)制設(shè)置圖形為圓。 textStyle: { color: "red"http:// 設(shè)置文本為紅色 } }] },
option.toolbox
toolbox: { orient: "vertical",//工具欄 icon 的布局朝向{vertical/horizontal} show: true,//默認(rèn)不顯示 feature: { //各工具配置項(xiàng) dataZoom: {yAxisIndex: "none"}, //區(qū)域縮放 dataView: {readOnly: false}, //查看源數(shù)據(jù),false時(shí)可更改 magicType: {type: ["line", "bar"]}, //折線圖和柱狀圖切換 restore: {}, //刷新 saveAsImage: {} //保存圖像 } },
option.xAxis
xAxis: { position: "top", //X軸位置,default:bottom name: "evsion", //X坐標(biāo)軸名稱 type: "category", //坐標(biāo)軸類型{value,category,time,log} boundaryGap: false, //坐標(biāo)軸兩邊留白策略,類目軸和非類目軸的設(shè)置和表現(xiàn)不一樣 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", //坐標(biāo)軸刻度的相關(guān)設(shè)置 axisLabel: { formatter: "{value}~~~~" } },
option.series 系列列表。每個(gè)系列通過(guò) type 決定自己的圖表類型, 每個(gè) type 對(duì)應(yīng)不同的屬性
option.radar 雷達(dá)圖坐標(biāo)系組件,只適用于雷達(dá)圖
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, //星期標(biāo)簽與軸線之間的距離 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],//實(shí)際運(yùn)用中用數(shù)組代替Array //描點(diǎn) markPoint: { data: [ { type: "max", name: "最大值" }, { type: "min", name: "最小值" }] }, //直線 markLine: { data: [{ type: "average", name: "平均值" }] } },
pie
series: [{ name: "XXX",//餅圖某部分激活時(shí)名稱 type: "pie", radius: "55%",//規(guī)定餅圖大小 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: {//激活時(shí)樣式 emphasis: { shadowBlur: 10, shadowOffsetX: 0, shadowColor: "rgba(0, 0, 0, 0.5)" } } }] };
radar
series: [{ name: "系統(tǒng)商品數(shù)量統(tǒng)計(jì)", type: "radar", data : [ { value : gnum, name : "庫(kù)存" }, { value : snum, name : "銷售" }, { value : cnum, name : "評(píng)論" } ] }]
map 注意ECharts3不再支持內(nèi)置地圖,需要到ECharts-Map按需下載
series: [ { name: "XXX", type: "map", mapType: "湖南",//這里與配置的地圖有關(guān),注意省要用中文 selectedMode : "multiple",//選中模式,表示是否支持多個(gè)選中,默認(rèn)關(guān)閉{single/multiple} //圖形上的文本標(biāo)簽,可用于說(shuō)明圖形的一些數(shù)據(jù)信息 label: { //是否在普通狀態(tài)下顯示標(biāo)簽。 normal: { show: true }, //是否在高亮狀態(tài)下顯示標(biāo)簽。 emphasis: { show: true } }, data:[ {name:"A", value: 100}//注意A需要與mapType里面的值相對(duì)應(yīng) ] },
init
var myChart = echarts.init(document.getElementById("X"));//JQuery需要($("#X")[0])
config.option
var Xoption = { code...//內(nèi)容既為CONFIG部分 }
setOption
myChart.setOption(Xoption);
event.click
這里params顯示點(diǎn)擊塊的所有配置,然后自動(dòng)跳轉(zhuǎn)到百度并搜索,params.name代表點(diǎn)擊事件觸發(fā)時(shí)的取值
myChart.on("click", function(params) { window.open("https://www.baidu.com/s?wd=" + encodeURIComponent(params.name)); });pin
它能將任意頁(yè)面元素“釘”在某個(gè)容器頂部,而且在尺寸小的屏幕上能夠自動(dòng)禁用這種效果
將某元素“釘”在容器內(nèi)
$(".pinned").pin({ containerSelector: ".container" })
在小尺寸的屏幕上禁用Pin效果
$(".pinned").pin({ minWidth: 940 })
直接引用 jquery.pin.js 即可
revaelJsreveal.js是一個(gè)能夠幫助我們很輕易地使用HTML來(lái)創(chuàng)建漂亮的PPT演示效果
reveal.js不依賴其他任何javascript庫(kù),是一個(gè)獨(dú)立的javascript插件庫(kù)
options
// 是否在右下角展示控制條 controls: true, // 是否顯示演示的進(jìn)度條 progress: true, // 是否顯示當(dāng)前幻燈片的頁(yè)數(shù) slideNumber: "c/t", // 是否將每個(gè)幻燈片改變加入到瀏覽器的歷史記錄中去 history: false, // 是否啟用鍵盤快捷鍵來(lái)導(dǎo)航 keyboard: true, // 是否啟用幻燈片的概覽模式,開啟后,可以使用ESC鍵查看幻燈片概覽 overview: true, // 是否將幻燈片垂直居中 center: true, // 是否在觸屏設(shè)備上啟用觸摸導(dǎo)航 touch: true, // 是否循環(huán)演示 loop: false, // 是否將演示的方向變成 right to left rtl: false, // 全局開啟和關(guān)閉碎片 fragments: true, // 標(biāo)識(shí)演示文稿是否在嵌入模式中運(yùn)行,即包含在屏幕的有限部分中的 embedded: false, // 標(biāo)識(shí)當(dāng)問(wèn)號(hào)鍵被點(diǎn)擊的時(shí)候是否應(yīng)該顯示一個(gè)幫助的覆蓋層 help: true, // 兩個(gè)幻燈片之間自動(dòng)切換的時(shí)間間隔(毫秒),當(dāng)設(shè)置成 0 的時(shí)候則禁止自動(dòng)切換,該值可以被幻燈片上的 ` data-autoslide` 屬性覆蓋 autoSlide: 0, // 當(dāng)遇到用戶輸入的時(shí)候停止切換 autoSlideStoppable: true, // 是否啟用通過(guò)鼠標(biāo)滾輪來(lái)導(dǎo)航幻燈片 mouseWheel: true, // 是否在移動(dòng)設(shè)備上隱藏地址欄 hideAddressBar: true, // 是否在一個(gè)彈出的 iframe 中打開幻燈片中的鏈接 previewLinks: false, // 切換過(guò)渡效果 transition: "default", // none/fade/slide/convex/concave/zoom // 過(guò)渡速度 transitionSpeed: "default", // default/fast/slow // 全屏幻燈片背景的過(guò)渡效果 backgroundTransition: "default", // none/fade/slide/convex/concave/zoom // 除當(dāng)前可見的之外的幻燈片數(shù)量 viewDistance: 3, // 視差背景圖片 parallaxBackgroundImage: "", // e.g. ""https://s3.amazonaws.com/hakim-static/reveal-js/reveal-parallax-1.jpg"" // 視差背景尺寸 parallaxBackgroundSize: "", // CSS syntax, e.g. "2100px 900px" // 移動(dòng)視差背景(水平和垂直)滑動(dòng)變化的數(shù)量, 例如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
CSS
HTML
JS
//初始化 Reveal.initialize({ //options... })material-icon
大方,美觀,跨平臺(tái),易于使用
CSS配置,可根據(jù)需求自行調(diào)節(jié)樣式
@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; }
配置CSS文件即可
DEMO
eventBootstrap Multiselect
Bootstrap Multiselect 是一個(gè)基于JQuery的插件,用于提供直觀的用戶界面,用于使用具有多個(gè)屬性的選擇輸入。
option.multiple 添加在 中,啟用多選
option.maxHeight 下拉框最大高度
maxHeight: 300
option.buttonWidth 觸發(fā)按鈕寬度
buttonWidth: "400px"
option.includeSelectAllOption 全選
includeSelectAllOption: true
option.enableFiltering 啟用篩選
enableFiltering: true
引入 JS 和 CSS 文件,在CSS文件內(nèi)進(jìn)行相關(guān)樣式的更改
創(chuàng)建一個(gè)下拉選擇框
初始化插件
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/82824.html
摘要:前端編程工具有很多,例如簡(jiǎn)稱,,,,等等,今天給大家推薦的是是一個(gè)完全免費(fèi)的軟件,頁(yè)面簡(jiǎn)介大方,是前端開發(fā)者最受歡迎的軟件之一。 前端編程工具有很多,例如Visua...
摘要:文章同步在微店前端工程化起步于一個(gè)內(nèi)部產(chǎn)品,對(duì)外我們有一個(gè)開源版本。這么長(zhǎng)時(shí)間過(guò)去了,我們?cè)谇岸斯こ袒矫嬗辛四男┳兓龅搅四男﹩?wèn)題用怎樣的方案解決這些問(wèn)題等等,值得為大家再分享。最終產(chǎn)品以命令行的形式發(fā)布。 文章同步在:https://github.com/hoperyy/bl... 微店前端工程化起步于一個(gè)內(nèi)部產(chǎn)品 vbuilder,對(duì)外我們有一個(gè)開源版本 bio-cli。 去年我...
摘要:授權(quán)破解版易優(yōu)企業(yè)建站系統(tǒng)易優(yōu)企業(yè)建站系統(tǒng)是一款十分優(yōu)秀專業(yè)的為企業(yè)創(chuàng)建網(wǎng)站服務(wù)的軟件。去版權(quán)破解版強(qiáng)大好用,為企業(yè)創(chuàng)建網(wǎng)站提供很多幫助和便利。直接去易優(yōu)官網(wǎng),購(gòu)買商業(yè)授權(quán)即可去除版權(quán)。eyoucms v1.4.9授權(quán)破解版(易優(yōu)企業(yè)建站系統(tǒng))是一款十分優(yōu)秀專業(yè)的為企業(yè)創(chuàng)建網(wǎng)站服務(wù)的軟件。eyoucms v1.4.9去版權(quán)破解版 強(qiáng)大好用,為企業(yè)創(chuàng)建網(wǎng)站提供很多幫助和便利。易優(yōu)cms破解授權(quán)...
摘要:作為年最具潛力,乃至最具影響力的前端開源項(xiàng)目真的不為過(guò)。通過(guò)上的介紹,這個(gè)項(xiàng)目是偏右阿里的前端大牛和阿里的前端大牛主導(dǎo),而且從中也不難看出有些部分是來(lái)自參與過(guò)的項(xiàng)目。 showImg(https://segmentfault.com/img/bVH8b2?w=900&h=500); 在2016年,前端的開源世界越發(fā)精彩,Vue的不斷壯大,Angular 2的發(fā)布,Amaze UI 3....
摘要:作為年最具潛力,乃至最具影響力的前端開源項(xiàng)目真的不為過(guò)。通過(guò)上的介紹,這個(gè)項(xiàng)目是偏右阿里的前端大牛和阿里的前端大牛主導(dǎo),而且從中也不難看出有些部分是來(lái)自參與過(guò)的項(xiàng)目。 showImg(https://segmentfault.com/img/bVH8b2?w=900&h=500); 在2016年,前端的開源世界越發(fā)精彩,Vue的不斷壯大,Angular 2的發(fā)布,Amaze UI 3....
閱讀 698·2021-11-22 09:34
閱讀 3831·2021-09-22 15:42
閱讀 1343·2021-09-03 10:28
閱讀 1082·2021-08-26 14:13
閱讀 1912·2019-08-29 15:41
閱讀 1440·2019-08-29 14:12
閱讀 3376·2019-08-26 18:36
閱讀 3320·2019-08-26 13:47