摘要:插件的依賴(lài)文件插件的使用頁(yè)面結(jié)構(gòu)設(shè)置日歷頭部信息,如果設(shè)置為,則不顯示頭部信息。設(shè)置日歷的高度,包括日歷頭部,默認(rèn)未設(shè)置,高度根據(jù)值自適應(yīng)。
先說(shuō)一下我的另一博客地址: https://home.cnblogs.com/u/bllx/
FullCalendar的選擇前段時(shí)間,一直在開(kāi)發(fā)考勤系統(tǒng),當(dāng)時(shí)為滿(mǎn)足設(shè)計(jì)的需求,選了好幾個(gè)插件,最后決定采用Fullcanlendar的插件。感覺(jué)這個(gè)插件可以滿(mǎn)足現(xiàn)階段的功能開(kāi)發(fā)需求;因?yàn)樵O(shè)計(jì)圖是日歷塊的展示以及每天的日歷還有功能需求點(diǎn),因此,想到了可以實(shí)現(xiàn)備忘錄的功能的FullCalendar插件。
為了實(shí)現(xiàn)設(shè)計(jì)圖,插件自身的樣式還是有些丑的,因此,很多樣式細(xì)節(jié)需要修改,插件的使用難點(diǎn)在于實(shí)現(xiàn)數(shù)據(jù)的渲染。
1、插件的依賴(lài)文件2、插件的使用
$("#calendar").fullCalendar({ /*設(shè)置日歷頭部信息,如果設(shè)置為false,則不顯示頭部信息。 * 包括left,center,right左中右三個(gè)位置都可以對(duì)應(yīng)一下配置 * title:顯示當(dāng)前月份/周、日信息 * prev:用于切換到上一月/周/日視圖的按鈕 * next:用于切換到下一月/周/日視圖的按鈕 * prevYear:用于切換到上一年視圖的按鈕 * nextYear:用于切換到下一年視圖的按鈕 * */ header:{ left: "", center: "Fullcanlendar示例demo", right: "today prev,next" }, theme:false,//如果設(shè)置為true,則需要加載jquery ui相關(guān)css和js文件,默認(rèn)值為false firstDay:1,//設(shè)置一周中顯示的第一天是哪天,周日是0,周一是1,類(lèi)推 isRTL:false,//設(shè)置為ture時(shí)則日歷從右往左顯示 weekends:true,//是否顯示周末,設(shè)為false則不顯示周六和周日。默認(rèn)值為true hiddenDays:[],//隱藏一周中的某一天或某幾天,數(shù)組形式,如隱藏周二和周五:[2,5],默認(rèn)不隱藏,除非weekends設(shè)置為false。 weekMode:"fixed",//在月視圖里顯示周的模式,因?yàn)槊吭轮軘?shù)可能不同,所以月視圖高度不一定。fixed:固定顯示6周高,日歷高度保持不變liquid:不固定周數(shù),高度隨周數(shù)變化variable:不固定周數(shù),但高度固定 weekNumbers:false,//是否在日歷中顯示周次(一年中的第幾周),如果設(shè)置為true,則會(huì)在月視圖的左側(cè)、周視圖和日視圖的左上角顯示周數(shù)。 weekNumberCalculation:"iso",//周次的顯示格式。 //height:600,//設(shè)置日歷的高度,包括header日歷頭部,默認(rèn)未設(shè)置,高度根據(jù)aspectRatio值自適應(yīng)。 //contentHeight://設(shè)置日歷主體內(nèi)容的高度,不包括header部分,默認(rèn)未設(shè)置,高度根據(jù)aspectRatio值自適應(yīng)。 aspectRatio:1.35,//設(shè)置日歷單元格寬度與高度的比例。 handleWindowResize:true,//是否隨瀏覽器窗口大小變化而自動(dòng)變化。 render:function(view){ console.log("render",view) },//method,綁定日歷到id上。$("#id").fullCalendar("render"); destroy:function(){ }, weekNumbers : false, //是否在視圖左邊顯示這是第多少周,默認(rèn)false eventLimit: true, //數(shù)據(jù)條數(shù)太多時(shí),限制各自里顯示的數(shù)據(jù)條數(shù)(多余的以“+2more”格式顯示),默認(rèn)false不限制,支持輸入數(shù)字設(shè)定固定的顯示條數(shù) viewRender : function(view,element){//在視圖被渲染時(shí)觸發(fā)(切換視圖也觸發(fā)) 參數(shù)view為視圖對(duì)象,參數(shù)element為Jquery的視圖Dom }, dayRender : function(date, cell){//日期格式Render鉤子函數(shù)(我沒(méi)理解清楚) console.log("↓↓↓dayRender↓↓↓"); console.log(date); console.log(cell); }, windowResize : function(){//瀏覽器窗體變化時(shí)觸發(fā) console.log("---windowResize---"); }, allDayText : "全天", //自定義全天視圖的名稱(chēng) slotDuration : "01:00:00", //一格時(shí)間槽代表多長(zhǎng)時(shí)間,默認(rèn)00:30:00(30分鐘) slotLabelFormat : "H(:mm)a", //日期視圖左邊那一列顯示的每一格日期時(shí)間格式 slotLabelInterval : "02:00:00", //日期視圖左邊那一列多長(zhǎng)間隔顯示一條日期文字(默認(rèn)跟著slotDuration走的,可自定義) snapDuration : "05:00:00", //其實(shí)就是動(dòng)態(tài)創(chuàng)建一個(gè)日程時(shí),默認(rèn)創(chuàng)建多長(zhǎng)的時(shí)間塊 slotEventOverlap : false, //相同時(shí)間段的多個(gè)日程視覺(jué)上是否允許重疊,默認(rèn)true允許 noEventsMessage : "L沒(méi)數(shù)據(jù)啊", //listview視圖下,無(wú)數(shù)據(jù)時(shí)顯示提示 defaultDate : "2018-09-10", //默認(rèn)顯示那一天的日期視圖getDates(true) nowIndicator : true, //周/日視圖中顯示今天當(dāng)前時(shí)間點(diǎn)(以紅線(xiàn)標(biāo)記),默認(rèn)false不顯示 monthNames : ["一月", "二月", "三月", "四月", "五月", "六月", "七月", "八月", "九月", "十月", "十一月", "十二月"], //月份自定義命名 monthNamesShort: ["一月", "二月", "三月", "四月", "五月", "六月", "七月", "八月", "九月", "十月", "十一月", "十二月"], //月份縮略命名(英語(yǔ)比較實(shí)用:全稱(chēng)January可設(shè)置縮略為Jan) dayNames: ["周日", "周一", "周二", "周三", "周四", "周五", "周六"], //同理monthNames dayNamesShort: ["周日", "周一", "周二", "周三", "周四", "周五", "周六"], //同理monthNamesShort weekNumberTitle : "周", //周的國(guó)際化,默認(rèn)為"W" eventLimitText : "更多", //當(dāng)一塊區(qū)域內(nèi)容太多以"+2 more"格式顯示時(shí),這個(gè)more的名稱(chēng)自定義(應(yīng)該與eventLimit: true一并用) dayPopoverFormat : "YYYY年M月d日", //點(diǎn)開(kāi)"+2 more"彈出的小窗口標(biāo)題,與eventLimitClick可以結(jié)合用 navLinks : true, // “xx周”是否可以被點(diǎn)擊,默認(rèn)false,如果為true則周視圖“周幾”被點(diǎn)擊之后進(jìn)入日視圖。本地測(cè)試:沒(méi)什么效果 dayClick: function(date, jsEvent, view) {//空白的日期區(qū),單擊時(shí)觸發(fā) console.log("↓↓↓dayClick↓↓↓"); console.log("Clicked on: " + date.format()); console.log("Coordinates: " + jsEvent.pageX + "," + jsEvent.pageY); console.log("Current view: " + view.name); //$(this).css("background-color", "red"); }, eventClick: function(calEvent, jsEvent, view) {//日程區(qū)塊,單擊時(shí)觸發(fā) console.log(jsEvent.target) alert(jsEvent.target.innerHTML) console.log("↓↓↓eventClick↓↓↓"); console.log("Event: " + calEvent.title); console.log("Coordinates: " + jsEvent.pageX + "," + jsEvent.pageY); console.log("Current view: " + view.name); return false; //return false可以阻止點(diǎn)擊后續(xù)事件發(fā)生(比如event中的url跳轉(zhuǎn)事件) }, eventMouseover: function(calEvent, jsEvent, view){//鼠標(biāo)在日程區(qū)塊上時(shí)觸發(fā) console.log(jsEvent) console.log(calEvent.start._i) $(".hover-dateStr").html(calEvent.start._i) console.log(jsEvent.pageY,jsEvent.pageX) $(".hover-container").removeClass("none").animate({"top":jsEvent.pageY,"left":jsEvent.pageX}) if(!canRun){ // 判斷是否已空閑,如果在執(zhí)行中,則直接return return; } }, eventMouseout: function(calEvent, jsEvent, view){//鼠標(biāo)從日程區(qū)塊離開(kāi)時(shí)觸發(fā) $(".hover-container").addClass("none") }, selectable: false, //允許用戶(hù)可以長(zhǎng)按鼠標(biāo)選擇多個(gè)區(qū)域(比如月視圖,可以選中多天;日視圖可以選中多個(gè)小時(shí)),默認(rèn)false不能選擇多區(qū)域的 selectHelper: true, //接selectable,周/日視圖在選擇時(shí)是否預(yù)先畫(huà)出“日程區(qū)塊”的樣式出來(lái) unselectAuto : true, //是否點(diǎn)擊頁(yè)面上的其他地方會(huì)導(dǎo)致當(dāng)前的選擇被清除,默認(rèn)true unselectCancel : "", //一種方法來(lái)指定元素,會(huì)忽略u(píng)nselectauto選項(xiàng),默認(rèn)"" selectOverlap : true, //確定用戶(hù)是否被允許選擇被事件占用的時(shí)間段,默認(rèn)true可占用時(shí)間段 selectAllow : function(selectInfo){ //精確的編程控制用戶(hù)可以選擇的地方,返回true則表示可選擇,false表示不可選擇 console.log("↓↓↓selectConstraint↓↓↓"); console.log("start:"+selectInfo.start+"|end:"+selectInfo.end+"|resourceId:"+selectInfo.resourceId); return true; }, select: function(start, end,jsEvent,view) { //點(diǎn)擊空白區(qū)域/選擇區(qū)域內(nèi)容觸發(fā) }, unselect : function(view, jsEvent){//選擇操作取消時(shí)觸發(fā) console.log("↓↓↓unselect↓↓↓"); console.log("view:"+view); }, lazyFetching : true, //是否啟用懶加載技術(shù)--即只取當(dāng)前條件下的視圖數(shù)據(jù),其它數(shù)據(jù)在切換時(shí)觸發(fā),默認(rèn)true只取當(dāng)前視圖的,false是取全視圖的 defaultTimedEventDuration : "02:00:00", //在Event Object中如果沒(méi)有end參數(shù)時(shí)使用,如start=7:00pm,則該日程對(duì)象時(shí)間范圍就是7:00~9:00 defaultAllDayEventDuration : { days: 1 }, //默認(rèn)1天是多長(zhǎng),(有的是采用工作時(shí)間模式,所以支持自定義) loading : function(isLoading, view){ //視圖數(shù)據(jù)加載中、加載完成觸發(fā) console.log("↓↓↓loading↓↓↓"); if(isLoading == true){ console.log("view:"+view+",開(kāi)始加載"); }else if(isLoading == false){ console.log("view:"+view+",加載完成"); }else{ console.log("view:"+view+",除非天塌下來(lái)否則不會(huì)進(jìn)這個(gè)分支"); } }, eventOrder : "title", //多個(gè)相同的日程數(shù)據(jù)排序方式,String / Array / Function, 默認(rèn)值: "title" eventRender : function(event, element, view) { //當(dāng)Event對(duì)象開(kāi)始渲染時(shí)觸發(fā) console.log("eventRender():"+event.title); }, eventAfterAllRender : function(view){console.log("eventAfterAllRender();");}, //當(dāng)所有Event對(duì)象渲染完成時(shí)觸發(fā) editable: true, //支持Event日程拖動(dòng)修改,默認(rèn)false eventStartEditable : true, //Event日程開(kāi)始時(shí)間可以改變,默認(rèn)true,如果是false其實(shí)就是指日程塊不能隨意拖動(dòng),只能上下拉伸改變他的endTime eventDurationEditable : false, //Event日程的開(kāi)始結(jié)束時(shí)間距離是否可以改變,默認(rèn)true,如果是false則表示開(kāi)始結(jié)束時(shí)間范圍不能拉伸,只能拖拽 dragOpacity:0.2, //拖拽時(shí)不透明度,0.0~1.0之間,數(shù)字越小越透明 dragScroll : true, //是否在拖拽時(shí)自動(dòng)移動(dòng)容器,默認(rèn)true eventOverlap : true, //拖拽時(shí)是否重疊 eventConstraint : { //限制拖拽拖放的位置(即限制有些地方拖不進(jìn)去):an event ID, "businessHours", object start: "10:00", // a start time (10am in this example) end: "18:00", // an end time (6pm in this example) dow: [ 1, 2, 3, 4 ] // days of week. an array of zero-based day of week integers (0=Sunday) (Monday-Thursday in this example) }, longPressDelay : 1000, //面向可touch設(shè)備(如移動(dòng)設(shè)備),長(zhǎng)按多少毫秒即可拖動(dòng),默認(rèn)1000毫秒(1S) eventDragStart : function(event, jsEvent, ui, view){ //日程開(kāi)始拖拽時(shí)觸發(fā) console.log("eventDragStart():"+event.title); }, eventDragStop : function(event, jsEvent, ui, view){ //日程拖拽停止時(shí)觸發(fā) console.log("eventDragStop():"+event.title); }, eventDrop : function(event, delta, revertFunc, jsEvent, ui, view){ //日程拖拽停止并且已經(jīng)拖拽到其它位置了 console.log("eventDrop():"+event.title); }, eventResizeStart : function( event, jsEvent, ui, view ) { //日程大小調(diào)整開(kāi)始時(shí)觸發(fā) console.log("eventResizeStart():"+event.title); }, eventResizeStop : function(event, jsEvent, ui, view){ //日程大小調(diào)整停止時(shí)觸發(fā) console.log("eventResizeStop():"+event.title); }, eventResize : function(event, delta, revertFunc, jsEvent, ui, view){ //日程大小調(diào)整完成并已經(jīng)執(zhí)行更新時(shí)觸發(fā) console.log("eventResize():"+event.title); }, events:[ { "time": "9:20--18:20", "antualTime":"9:40--18:40", "start": "2018-09-01" }, { "time": "9:40--18:40", "antualTime":"9:40--18:40", "start": "2018-09-02" } ] });3、獲取數(shù)據(jù)
如果將數(shù)據(jù)源向上述代碼中放置的話(huà),是直接一次渲染所有數(shù)據(jù),在切換不同月份的時(shí)候,將不會(huì)再次渲染,這就會(huì)在頁(yè)面一開(kāi)始加載時(shí)請(qǐng)求服務(wù)器,渲染所有數(shù)據(jù),源碼中在切換前后相鄰月份的時(shí)候,也是重新渲染了數(shù)據(jù),我們想要的是在切換月份的時(shí)候,再去請(qǐng)求服務(wù)器獲取該月份的數(shù)據(jù)
//初始化日程表 events:function(start, end, timezone,callback){ var date = this.getDate().format("YYYY-MM"); var arr=date.split("-"); var events = loopMonthDay(arr[0],arr[1]);// loopMonthDay(arr[0],arr[1]);是自己封裝的函數(shù) callback(events);//回調(diào)中執(zhí)行渲染 }
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/98876.html
摘要:原文鏈接前端插件庫(kù)站點(diǎn)前端開(kāi)發(fā)文檔博客前端插件庫(kù)前端插件庫(kù)官網(wǎng)是的函數(shù)庫(kù),目的是強(qiáng)化表格操作如搜索排序,并自動(dòng)加入組件引入表格中,使用非常靈活簡(jiǎn)便。由推出,靈活扎實(shí)的建議列表函數(shù)庫(kù)。 原文鏈接:前端插件庫(kù)站點(diǎn):前端開(kāi)發(fā)文檔博客:前端插件庫(kù) 前端插件庫(kù) DataTables 官網(wǎng):https://www.datatables.net/ DataTables是jQuery的JavaScr...
摘要:原文鏈接前端插件庫(kù)站點(diǎn)前端開(kāi)發(fā)文檔博客前端插件庫(kù)前端插件庫(kù)官網(wǎng)是的函數(shù)庫(kù),目的是強(qiáng)化表格操作如搜索排序,并自動(dòng)加入組件引入表格中,使用非常靈活簡(jiǎn)便。由推出,靈活扎實(shí)的建議列表函數(shù)庫(kù)。 原文鏈接:前端插件庫(kù)站點(diǎn):前端開(kāi)發(fā)文檔博客:前端插件庫(kù) 前端插件庫(kù) DataTables 官網(wǎng):https://www.datatables.net/ DataTables是jQuery的JavaScr...
摘要:本項(xiàng)目由共同開(kāi)發(fā)完成前端后端截圖展示登錄首頁(yè)人員信息系統(tǒng)監(jiān)控模塊系統(tǒng)日志建議去在線(xiàn)瀏覽一下在線(xiàn)瀏覽地址地址碼云地址設(shè)計(jì)書(shū)環(huán)境框架插件工具內(nèi)置用于記錄日志文件內(nèi)置用戶(hù)緩存前端使用的模板用于標(biāo)簽的代碼高亮內(nèi)置用于顯示統(tǒng)一圖標(biāo)內(nèi)置一個(gè)帶備注 showImg(https://segmentfault.com/img/bVbnFyA?w=1920&h=949); 本項(xiàng)目由 zzzmh & csy...
摘要:修復(fù)后得到合法的后在由布局引擎建立相應(yīng)的對(duì)象。在標(biāo)簽放置于標(biāo)簽之后時(shí),源碼被所有瀏覽器泛指上常見(jiàn)的修復(fù)為正常形式,即。上一篇之模板的學(xué)習(xí)之路源碼分析之部分下一篇之模板的學(xué)習(xí)之路主題布局配置 上篇我們將 body 標(biāo)簽主體部分進(jìn)行了簡(jiǎn)單總覽,下面看看最后的腳本部門(mén)。 頁(yè)面結(jié)尾部分(Javascripts 腳本文件) 我們來(lái)看看代碼最后的代碼,摘取如下: ...
閱讀 2806·2021-11-17 09:33
閱讀 4485·2021-09-22 15:57
閱讀 2880·2019-08-30 14:16
閱讀 3143·2019-08-29 14:07
閱讀 2424·2019-08-26 11:55
閱讀 3436·2019-08-23 17:07
閱讀 1734·2019-08-23 16:50
閱讀 2548·2019-08-23 16:08