摘要:返回指定范圍的隨機(jī)數(shù)之間的公式會(huì)阻擋預(yù)設(shè)要發(fā)生的事件會(huì)阻擋發(fā)生冒泡事件而則是前面兩者的事情他都會(huì)做他會(huì)做他會(huì)做停止的執(zhí)行并且立即回來(lái)防止被嵌套兩種圖片加載的方式第一個(gè)中級(jí)交流群成都獵巫第二個(gè)上海準(zhǔn)備為圖片預(yù)加載使用的插件使用的圖片
1. PC - js
返回指定范圍的隨機(jī)數(shù)(m-n之間)的公式
Math.random()*(n-m)+m
return false
return false
// event.preventDefault()會(huì)阻擋預(yù)設(shè)要發(fā)生的事件. // event.stopPropagation()會(huì)阻擋發(fā)生冒泡事件. // 而return false則是前面兩者的事情他都會(huì)做: // 他會(huì)做event.preventDefault(); // 他會(huì)做event.stopPropagation(); // 停止callback function的執(zhí)行并且立即return回來(lái)
防止被Iframe嵌套
if(top != self){ location.href = ”about:blank”; }
兩種圖片lazy加載的方式
第一個(gè)By JS中級(jí)交流群 成都-獵巫 第二個(gè)By 上海-zenki
// @description 準(zhǔn)備為圖片預(yù)加載使用的插件 // 使用的圖片容器css類(lèi)名為lazy-load-wrap // 圖片真實(shí)地址為data-lazy-src // 當(dāng)lazy-load-wrap容器進(jìn)入視口,則開(kāi)始替換容器內(nèi)所有需要延遲加載的圖片路徑,并更改容器的加載狀態(tài) //第一種方法 $.fn.compassLazyLoad=function(){ var _HEIGHT=window.innerHeight, _lazyLoadWrap=$(".lazy-load-wrap"); var methods={ setOffsetTop:function(){ $.each(_lazyLoadWrap,function(i,n){ $(n).attr({ "top":n.offsetTop-_HEIGHT, "status":"wait" }); }) }, isShow:function(){ var _scrollTop=$(window).scrollTop; //利用image容器判斷是否進(jìn)入視口,而非image本身 $.each(_lazyLoadWrap,function(){ var _that=$(this); if (_that.attr("status")==="done") { return; }; if (_that.attr("top")<=_scrollTop) { _that.find("img[data-lazy-src]").each(function(i,n){ n.src=$(n).data("lazy-src"); }); _that.attr("status","done"); }; }) }, scroll:function(){ $(window).on("scroll",function(){ methods.isShow(); }); }, init:function(){ methods.setOffsetTop(); methods.isShow(); methods.scroll(); } }; methods.init(); } //第二種方法 var exist=(function($){ var timer=null, temp=[].slice.call($(".container")); ret={}; for(var i=0,len=temp.length-1;i<=len;i++){ ret[i]=temp[i]; } var isExist=function(winTop,winEnd){ for(var i in ret){ console.log(ret); var item=ret[i], eleTop=item.offsetTop, eleEnd=eleTop+item.offsetHeight; if((eleTop>winTop&&eleTop<=winEnd)||(eleEnd>winTop&&eleEnd<=winEnd)){ $(item).css("background","none"); new Tab($(item).attr("id"),data).init; delete ret[i]; } } } return { timer:timer; isExist:isExist; }; })($); //第三種方法 Zepto(function ($) { var swiper = new Swiper(".swiper-container", { pagination: ".swiper-pagination", paginationClickable: true, autoplay: 3000, loop: true, autoplayDisableOnInteraction: false }); (function lazyLoad() { var imgs = $(".lazyLoad"); var src = ""; $.each(imgs, function (index, item) { src = $(item).attr("data-src"); $(item).attr("src", src); }); })(); }); $(function () { var lazyLoadTimerId = null; /// 智能加載事件 $(window).bind("scroll", function () { clearTimeout(lazyLoadTimerId); lazyLoadTimerId = setTimeout(function () { // 延遲加載所有圖片 var isHttp = (location.protocol === "http:"); $("#ym_images img").each(function () { var self = $(this); if (self.filter(":above-the-fold").length > 0) { var originUrl = self.attr("data-original"); self.attr("src", originUrl); } }); }, 500); }); });
某年某月的1號(hào)為星期幾
var weekday = ["星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六"]; weekday[new Date(2015, 9, 1).getDay()]; //2015年10月1號(hào)2. Mobile - js
js 判斷IOS, 安卓
var u = navigator.userAgent, app = navigator.appVersion; var isAndroid = u.indexOf("Android") > -1 || u.indexOf("Linux") > -1; //android終端或者uc瀏覽器 var isiOS = !!u.match(/(i[^;]+;( U;)? CPU.+Mac OS X/); //ios終端 alert("是否是Android:"+isAndroid); alert("是否是iOS:"+isiOS);3. 微信 weixin
UserAgent 判斷微信客戶(hù)端
// Mozilla/5.0 (iPhone; CPU iPhone OS 8_3 like Mac OS X) AppleWebKit/600.1.4 (KHTML, like Gecko) Mobile/12F70 MicroMessenger/6.1.5 NetType/WIFI function isWechat() { var ua = navigator.userAgent.toLowerCase(); return /micromessenger/i.test(ua) || /windows phone/i.test(ua); }
JS接口安全域名不填寫(xiě),分享onMenuShareAppMessage直接會(huì)取默認(rèn)值。
// 分享onMenuShareAppMessage直接會(huì)取默認(rèn)值
關(guān)閉當(dāng)前頁(yè)面
WeixinJSBridge.call("closeWindow");
支付接口方法調(diào)用必須在addevent里邊調(diào)用
document.addEventListener("WeixinJSBridgeReady", function onBridgeReady(){ that.initOrder(); }, false);
支付接口方法調(diào)用必須在
WeixinJSBridge.invoke("getBrandWCPayRequest", d, function(res){ if(res.err_msg == "get_brand_wcpay_request:ok"){ // alert("支付成功"); // union.release(d.orderId); resetUrl(); paySuccess("home", d.orderId); } else { cancelOrder(d.orderId); // alert(res.err_msg); } loading.hide(); });
瀑布流無(wú)限加載實(shí)例
// be dependent on jquery & jquery.infinitescroll.min.js // insert this "" to your page.html (function($){ $(function(){ var $container = $(".list-wrap-gd"); function layOutCallBack() { $container.imagesLoaded(function(){ $container.masonry({ itemSelector: ".item-bar", gutter: 10 }); }); $container.imagesLoaded().progress( function() { $container.masonry("layout"); }); } layOutCallBack(); $container.infinitescroll({ navSelector : "#more", nextSelector : "#more a", itemSelector : ".item-bar", pixelsFromNavToBottom: 300, loading:{ img: "/images/masonry_loading.gif", msgText: " ", finishedMsg: "已經(jīng)到最后一頁(yè)", finished: function(){ $("#more").remove(); $("#infscr-loading").hide(); } }, errorCallback:function(){ $(window).unbind(".infscr"); }, pathParse: function (path, nextPage) { var query = ""; var keyword=$("#search_keyword").val(); var cat_id=$("#cat_id").val(); var brand_id=$("#brand_id").val(); var country_id = $("#country_id").val(); query = query + "&namekeyword="+keyword; query = query +"&cat_id="+cat_id query = query + "&brand_id=" + brand_id; query = query + "&country_id=" + country_id; path = [path,query]; return path; } }, function(newElements) { var $newElems = $( newElements ).css({ opacity: 0 }); $newElems.imagesLoaded(function(){ $newElems.animate({ opacity: 1 }); $container.masonry( "appended", $newElems, true ); layOutCallBack(); }); }); }); })(jQuery);
iOS,Safari瀏覽器,input等表單focus后fixed元素錯(cuò)位問(wèn)題
if( /iPhone|iPod|iPad/i.test(navigator.userAgent) ) { $(document).on("focus", "input, textarea", function() { $("header").css("position", "absolute"); $("footer").css("position", "absolute"); }); $(document).on("blur", "input, textarea", function() { $("header").css("position", "fixed"); $("footer").css("position", "fixed"); }); }
得到地理位置
function getLocation(callback){ if(navigator.geolocation){ navigator.geolocation.getCurrentPosition( function(p){ callback(p.coords.latitude, p.coords.longitude); }, function(e){ var msg = e.code + " " + e.message; } ); } }
rem計(jì)算適配
(function(doc, win){ var docEl = doc.documentElement, resizeEvt = "orientationchange" in window ? "orientationchange" : "resize", recalc = function(){ var clientWidth = docEl.clientWidth; if(!clientWidth) return; docEl.style.fontSize = 20 * (clientWidth / 320) + "px"; }; if(!doc.addEventListener) return; win.addEventListener(resizeEvt, recalc, false); doc.addEventListener("DOMContentLoaded", recalc, false); })(document, window);
另外一種rem方案
var dpr, rem, scale; var docEl = document.documentElement; var fontEl = document.createElement("style"); var metaEl = document.querySelector("meta[name="viewport"]"); dpr = window.devicePixelRatio || 1; rem = docEl.clientWidth * 2 / 10; scale = 1 / dpr; // 設(shè)置viewport,進(jìn)行縮放,達(dá)到高清效果 metaEl.setAttribute("content", "width=" + dpr * docEl.clientWidth + ",initial-scale=" + scale + ",maximum-scale=" + scale + ", minimum-scale=" + scale + ",user-scalable=no"); // 設(shè)置data-dpr屬性,留作的css hack之用 docEl.setAttribute("data-dpr", dpr); // 動(dòng)態(tài)寫(xiě)入樣式 docEl.firstElementChild.appendChild(fontEl); fontEl.innerHTML = "html{font-size:" + rem + "px!important;}"; // 給js調(diào)用的,某一dpr下rem和px之間的轉(zhuǎn)換函數(shù) window.rem2px = function(v) { v = parseFloat(v); return v * rem; }; window.px2rem = function(v) { v = parseFloat(v); return v / rem; }; window.dpr = dpr; window.rem = rem;
獲取js所在路徑
function getJsDir (src) { var script = null; if (src) { script = [].filter.call(document.scripts, function (v) { return v.src.indexOf(src) !== -1; })[0]; } else { script = document.scripts[document.scripts.length - 1]; } return script ? script.src.substr(0, script.src.lastIndexOf("/")) : script; }
從全局捕獲錯(cuò)誤
window.onerror = function (errMsg, scriptURI, lineNumber, columnNumber, errorObj) { setTimeout(function () { var rst = { "錯(cuò)誤信息:": errMsg, "出錯(cuò)文件:": scriptURI, "出錯(cuò)行號(hào):": lineNumber, "出錯(cuò)列號(hào):": columnNumber, "錯(cuò)誤詳情:": errorObj }; alert(JSON.stringify(rst, null, 10)); }); };1. 常用方法 - js
字符串長(zhǎng)度截取
function cutstr(str, len) { var temp, icount = 0, patrn = /[^x00-xff]/, strre = ""; for (var i = 0; i < str.length; i++) { if (icount < len - 1) { temp = str.substr(i, 1); if (patrn.exec(temp) == null) { icount = icount + 1 } else { icount = icount + 2 } strre += temp } else { break; } } return strre + "..." }
替換全部
String.prototype.replaceAll = function(s1, s2) { return this.replace(new RegExp(s1, "gm"), s2) }
清除空格
String.prototype.trim = function() { var reExtraSpace = /^s*(.*?)s+$/; return this.replace(reExtraSpace, "$1") }
清除左空格/右空格
function ltrim(s){ return s.replace( /^(s*| *)/, ""); } function rtrim(s){ return s.replace( /(s*| *)$/, ""); }
判斷是否以某個(gè)字符串開(kāi)頭
String.prototype.startWith = function (s) { return this.indexOf(s) == 0 }
判斷是否以某個(gè)字符串結(jié)束
String.prototype.endWith = function (s) { var d = this.length - s.length; return (d >= 0 && this.lastIndexOf(s) == d) }
轉(zhuǎn)義html標(biāo)簽
function HtmlEncode(text) { return text.replace(/&/g, "&").replace(/"/g, """).replace(//g, ">") }
時(shí)間日期格式轉(zhuǎn)換
Date.prototype.Format = function(formatStr) { var str = formatStr; var Week = ["日", "一", "二", "三", "四", "五", "六"]; str = str.replace(/yyyy|YYYY/, this.getFullYear()); str = str.replace(/yy|YY/, (this.getYear() % 100) > 9 ? (this.getYear() % 100).toString() : "0" + (this.getYear() % 100)); str = str.replace(/MM/, (this.getMonth() + 1) > 9 ? (this.getMonth() + 1).toString() : "0" + (this.getMonth() + 1)); str = str.replace(/M/g, (this.getMonth() + 1)); str = str.replace(/w|W/g, Week[this.getDay()]); str = str.replace(/dd|DD/, this.getDate() > 9 ? this.getDate().toString() : "0" + this.getDate()); str = str.replace(/d|D/g, this.getDate()); str = str.replace(/hh|HH/, this.getHours() > 9 ? this.getHours().toString() : "0" + this.getHours()); str = str.replace(/h|H/g, this.getHours()); str = str.replace(/mm/, this.getMinutes() > 9 ? this.getMinutes().toString() : "0" + this.getMinutes()); str = str.replace(/m/g, this.getMinutes()); str = str.replace(/ss|SS/, this.getSeconds() > 9 ? this.getSeconds().toString() : "0" + this.getSeconds()); str = str.replace(/s|S/g, this.getSeconds()); return str }
判斷是否為數(shù)字類(lèi)型
function isDigit(value) { var patrn = /^[0-9]*$/; if (patrn.exec(value) == null || value == "") { return false } else { return true } }
設(shè)置cookie值
function setCookie(name, value, Hours) { var d = new Date(); var offset = 8; var utc = d.getTime() + (d.getTimezoneOffset() * 60000); var nd = utc + (3600000 * offset); var exp = new Date(nd); exp.setTime(exp.getTime() + Hours * 60 * 60 * 1000); document.cookie = name + "=" + escape(value) + ";path=/;expires=" + exp.toGMTString() + ";domain=360doc.com;" }
獲取cookie值
function getCookie(name) { var arr = document.cookie.match(new RegExp("(^| )" + name + "=([^;]*)(;|$)")); if (arr != null) return unescape(arr[2]); return null }
加載樣式文件表
function LoadStyle(url) { try { document.createStyleSheet(url) } catch(e) { var cssLink = document.createElement("link"); cssLink.rel = "stylesheet"; cssLink.type = "text/css"; cssLink.href = url; var head = document.getElementsByTagName("head")[0]; head.appendChild(cssLink) } }
返回腳本內(nèi)容
function evalscript(s) { if(s.indexOf("/ig; var arr = []; while(arr = p.exec(s)) { var p1 = //i; var arr1 = []; arr1 = p1.exec(arr[0]); if(arr1) { appendscript(arr1[1], "", arr1[2], arr1[3]); } else { p1 = //i; arr1 = p1.exec(arr[0]); appendscript("", arr1[2], arr1[1].indexOf("reload=") != -1); } } return s; }
清除腳本內(nèi)容
function stripscript(s) { return s.replace(/.*?/ig, ""); }
動(dòng)態(tài)加載腳本文件
function appendscript(src, text, reload, charset) { var id = hash(src + text); if(!reload && in_array(id, evalscripts)) return; if(reload && $(id)) { $(id).parentNode.removeChild($(id)); } evalscripts.push(id); var scriptNode = document.createElement("script"); scriptNode.type = "text/javascript"; scriptNode.id = id; scriptNode.charset = charset ? charset : (BROWSER.firefox ? document.characterSet : document.charset); try { if(src) { scriptNode.src = src; scriptNode.onloadDone = false; scriptNode.onload = function () { scriptNode.onloadDone = true; JSLOADED[src] = 1; }; scriptNode.onreadystatechange = function () { if((scriptNode.readyState == "loaded" || scriptNode.readyState == "complete") && !scriptNode.onloadDone) { scriptNode.onloadDone = true; JSLOADED[src] = 1; } }; } else if(text){ scriptNode.text = text; } document.getElementsByTagName("head")[0].appendChild(scriptNode); } catch(e) {} }
返回按ID檢索的元素對(duì)象
function $(id) { return !id ? null : document.getElementById(id); }
檢驗(yàn)URL鏈接是否有效
function getUrlState(URL){ var xmlhttp = new ActiveXObject("microsoft.xmlhttp"); xmlhttp.Open("GET",URL, false); try{ xmlhttp.Send(); }catch(e){ }finally{ var result = xmlhttp.responseText; if(result){ if(xmlhttp.Status==200){ return(true); }else{ return(false); } }else{ return(false); } } }
獲取當(dāng)前路徑
var currentPageUrl = ""; if (typeof this.href === "undefined") { currentPageUrl = document.location.toString().toLowerCase(); }else { currentPageUrl = this.href.toString().toLowerCase(); }
獲取頁(yè)面高度
function getPageHeight(){ var g = document, a = g.body, f = g.documentElement, d = g.compatMode == "BackCompat" ? a : g.documentElement; return Math.max(f.scrollHeight, a.scrollHeight, d.clientHeight); }
獲取頁(yè)面可視寬度
function getPageViewWidth(){ var d = document, a = d.compatMode == "BackCompat" ? d.body: d.documentElement; return a.clientWidth; }
獲取頁(yè)面寬度
function getPageWidth(){ var g = document, a = g.body, f = g.documentElement, d = g.compatMode == "BackCompat"? a: g.documentElement; return Math.max(f.scrollWidth, a.scrollWidth, d.clientWidth); }
隨機(jī)數(shù)時(shí)間戳
function uniqueId(){ var a=Math.random,b=parseInt; return Number(new Date()).toString()+b(10*a())+b(10*a())+b(10*a()); }
日期格式化函數(shù)
Date.prototype.format = function(format){ var o = { "M+" : this.getMonth()+1, //month "d+" : this.getDate(), //day "h+" : this.getHours(), //hour "m+" : this.getMinutes(), //minute "s+" : this.getSeconds(), //second "q+" : Math.floor((this.getMonth()+3)/3), //quarter "S" : this.getMilliseconds() //millisecond }; if(/(y+)/.test(format)) format=format.replace(RegExp.$1, (this.getFullYear()+"").substr(4 - RegExp.$1.length)); for(var k in o){ if(new RegExp("("+ k +")").test(format)) format = format.replace(RegExp.$1,RegExp.$1.length==1 ? o[k] :("00"+ o[k]).substr((""+ o[k]).length)); } return format; } //調(diào)用 //new Date().format("yyyy-MM-dd hh:mm:ss");
返回頂部的通用方法
function backTop(btnId) { var btn = document.getElementById(btnId); var d = document.documentElement; var b = document.body; window.onscroll = set; btn.style.display = "none"; btn.onclick = function() { btn.style.display = "none"; window.onscroll = null; this.timer = setInterval(function() { d.scrollTop -= Math.ceil((d.scrollTop + b.scrollTop) * 0.1); b.scrollTop -= Math.ceil((d.scrollTop + b.scrollTop) * 0.1); if ((d.scrollTop + b.scrollTop) == 0) clearInterval(btn.timer, window.onscroll = set); }, 10); }; function set() { btn.style.display = (d.scrollTop + b.scrollTop > 100) ? "block": "none" } }; backTop("goTop");
獲得URL中GET參數(shù)值
// 用法:如果地址是 test.htm?t1=1&t2=2&t3=3, 那么能取得:GET["t1"], GET["t2"], GET["t3"] function get_get(){ querystr = window.location.href.split("?") if(querystr[1]){ GETs = querystr[1].split("&"); GET = []; for(i=0;i數(shù)組去重
String.prototype.unique=function(){ var x=this.split(/[ ]+/); var y=""; for(var i=0;i按字典順序,對(duì)每行進(jìn)行數(shù)組排序
function SetSort(){ var text=K1.value.split(/[ ]/).sort().join(" ");//順序 var test=K1.value.split(/[ ]/).sort().reverse().join(" ");//反序 K1.value=K1.value!=text?text:test; }字符串反序輸出
function IsReverse(text){ return text.split("").reverse().join(""); }金額大寫(xiě)轉(zhuǎn)換函數(shù)
//格式轉(zhuǎn)換 function transform(tranvalue) { try { var i = 1; var dw2 = new Array("", "萬(wàn)", "億"); //大單位 var dw1 = new Array("拾", "佰", "仟"); //小單位 var dw = new Array("零", "壹", "貳", "叁", "肆", "伍", "陸", "柒", "捌", "玖"); //整數(shù)部分用 //以下是小寫(xiě)轉(zhuǎn)換成大寫(xiě)顯示在合計(jì)大寫(xiě)的文本框中 //分離整數(shù)與小數(shù) var source = splits(tranvalue); var num = source[0]; var dig = source[1]; //轉(zhuǎn)換整數(shù)部分 var k1 = 0; //計(jì)小單位 var k2 = 0; //計(jì)大單位 var sum = 0; var str = ""; var len = source[0].length; //整數(shù)的長(zhǎng)度 for (i = 1; i <= len; i++) { var n = source[0].charAt(len - i); //取得某個(gè)位數(shù)上的數(shù)字 var bn = 0; if (len - i - 1 >= 0) { bn = source[0].charAt(len - i - 1); //取得某個(gè)位數(shù)前一位上的數(shù)字 } sum = sum + Number(n); if (sum != 0) { str = dw[Number(n)].concat(str); //取得該數(shù)字對(duì)應(yīng)的大寫(xiě)數(shù)字,并插入到str字符串的前面 if (n == "0") sum = 0; } if (len - i - 1 >= 0) { //在數(shù)字范圍內(nèi) if (k1 != 3) { //加小單位 if (bn != 0) { str = dw1[k1].concat(str); } k1++; } else { //不加小單位,加大單位 k1 = 0; var temp = str.charAt(0); if (temp == "萬(wàn)" || temp == "億") //若大單位前沒(méi)有數(shù)字則舍去大單位 str = str.substr(1, str.length - 1); str = dw2[k2].concat(str); sum = 0; } } if (k1 == 3){ //小單位到千則大單位進(jìn)一 k2++; } } //轉(zhuǎn)換小數(shù)部分 var strdig = ""; if (dig != "") { var n = dig.charAt(0); if (n != 0) { strdig += dw[Number(n)] + "角"; //加數(shù)字 } var n = dig.charAt(1); if (n != 0) { strdig += dw[Number(n)] + "分"; //加數(shù)字 } } str += "元" + strdig; } catch(e) { return "0元"; } return str; } //拆分整數(shù)與小數(shù) function splits(tranvalue) { var value = new Array("", ""); temp = tranvalue.split("."); for (var i = 0; i < temp.length; i++) { value = temp; } return value; }
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/49663.html
摘要:常用模式片段之摘要第一次看到這個(gè)字眼是在中,即。之后也見(jiàn)到一些別人的代碼里有,它和頁(yè)面的有什么關(guān)系,以及和有何淵源。以前都見(jiàn)過(guò)這些詞,但都似懂非懂,今天查了些資料收集了些代碼,做個(gè)完整的理解。 CSS篇 常用模式片段之CSS布局篇 http://jsorz.cn/blog/2016/08/code-patterns-of-css-layout.html 摘要:position 拉伸性質(zhì)...
摘要:常用模式片段之摘要第一次看到這個(gè)字眼是在中,即。之后也見(jiàn)到一些別人的代碼里有,它和頁(yè)面的有什么關(guān)系,以及和有何淵源。以前都見(jiàn)過(guò)這些詞,但都似懂非懂,今天查了些資料收集了些代碼,做個(gè)完整的理解。 CSS篇 常用模式片段之CSS布局篇 http://jsorz.cn/blog/2016/08/code-patterns-of-css-layout.html 摘要:position 拉伸性質(zhì)...
摘要:在資源很多時(shí),例如圖片的復(fù)制,這個(gè)會(huì)加快任務(wù)的執(zhí)行速度,特別是需要實(shí)時(shí)預(yù)覽時(shí),減少延遲。但是作為個(gè)入門(mén)短時(shí)間內(nèi)還是不能夠被取代得了的。 gulp常用功能集合(開(kāi)發(fā)和生產(chǎn)分離、靜態(tài)資源壓縮優(yōu)化、代碼優(yōu)化、實(shí)時(shí)預(yù)覽、hash) tags: gulp 前端自動(dòng)化開(kāi)發(fā) npm倉(cāng)庫(kù)下載地址https://www.npmjs.com/package/cddgulp [TOC]本人自用在此基礎(chǔ)上的...
摘要:概述上一章講的是分離樣式,這一章講的是剩下的一些我常用的插件和上一章是沒(méi)有任何關(guān)系。環(huán)境搭建定義環(huán)境插件介紹這個(gè)插件用來(lái)定義環(huán)境變量的,直接定義在了下。安裝依賴(lài)添加資源修改配置打包其他更多配置請(qǐng)查閱關(guān)于資源源代碼 0x001 概述 上一章講的是分離樣式,這一章講的是剩下的一些我常用的插件,和上一章是沒(méi)有任何關(guān)系。 0x002 環(huán)境搭建 $ mkdir 0x0016-other-plug...
摘要:使用編輯器有一段時(shí)間一直沒(méi)找到比較順手的代碼片段補(bǔ)全于是決定自己整合一個(gè)全的于是便有了這個(gè)代碼片段包中包名叫有如下特性集成代碼補(bǔ)全集成中模塊的代碼補(bǔ)全集成中模塊的代碼補(bǔ)全集成集成中操作的代碼集成中和模塊的補(bǔ)全集成中代碼補(bǔ)全集成中集成中的 使用atom編輯器有一段時(shí)間,一直沒(méi)找到比較順手的代碼片段補(bǔ)全,于是決定自己整合一個(gè)全的,于是便有了這個(gè)代碼片段包,atom中包名叫 best-js-...
摘要:如果報(bào)表嵌在網(wǎng)頁(yè)的中,在外獲取對(duì)象如下常用方法方法說(shuō)明獲取指定單元格中的控件獲取指定名字的控件獲取指定名稱(chēng)的擴(kuò)展控件,返回一個(gè)數(shù)組表單預(yù)覽或參數(shù)界面,都有一個(gè)對(duì)象。 上次介紹FineReport的JS API中的第一類(lèi)開(kāi)發(fā)--FR,這次就來(lái)介紹一下FS和contentWindow類(lèi)的開(kāi)發(fā)。1 FSFS是數(shù)據(jù)決策系統(tǒng)中的js接口,比如說(shuō)FS.tabPane.addItem,先介紹幾類(lèi)操作...
閱讀 2781·2021-10-14 09:42
閱讀 838·2021-10-11 10:57
閱讀 785·2019-08-30 15:54
閱讀 1927·2019-08-30 13:50
閱讀 1693·2019-08-30 11:19
閱讀 943·2019-08-29 12:38
閱讀 1435·2019-08-26 11:51
閱讀 1401·2019-08-26 10:48