成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

前端常用函數(shù)積累

ACb0y / 1669人閱讀

摘要:參數(shù)對象數(shù)組,需要排序的目標要按排序的對象屬性名稱排序的方向,為從小到大是否使用模式,默認為,注意,使用該參數(shù)時前面的必須傳入。使用場景想要排列一個對象數(shù)組,條件是根據(jù)這些對象中的某個屬性。

cdd-lib

個人常用庫積累

說明

本庫是完全的es2015模塊語法,也使用了ts源碼。所以使用commonjs方式導致不可用。

路徑和引用說明

/index.js

根路徑的index.js文件為node_modules對外輸出的文件,是es6模塊方式。

/dist

dist文件夾里有集成的es6,cjs,umd,borowser方式的文件。

browser.js,umd供瀏覽器或者amd,cjs使用。

main.cjs.js, commmonjs模式。

module.es.js, es6模式。

安裝
npm i cdd-lib
Time

實例屬性與方法

constructor

interface $time {
  duration?: number
  everyDuration?: null | Function
  dateSeparator?: string
  timeSeparator?: string
  final?: null | Function
  finally?: null | Function
  times?: number
  date:any
}
declare function _Time(): $time;//構(gòu)造函數(shù)
declare interface $time {//time實例
  isRuning: boolean//實例現(xiàn)在的運行狀態(tài)
  hour: number//小時
  minutes: number//分鐘
  seconds: number//秒
  year: number//年
  times:numer//執(zhí)行timeout時倒數(shù)執(zhí)行的次數(shù)
  month: number//月
  day: number//日期
  stamp:number//創(chuàng)建是的時間戳
  duration:number//間隔毫秒數(shù)默認1000
  dateSeparator: string//日期分隔符默認-
  timeSeparator: string//時間分隔符默認:
  date: string//日期
  time: string//時間
  ap: string//上午還是下午AM PM
  start(): any//開始循環(huán)執(zhí)行
  stop(): any//結(jié)束循環(huán)執(zhí)行
  everyDuration?(parms?: any): any//每次執(zhí)行的函數(shù)
  timeout.timeout():any//倒數(shù)執(zhí)行的函數(shù)
  final():cb倒數(shù)執(zhí)行完時執(zhí)行的回到函數(shù)
}
limitText

限制一段文字的長短并添加符號,類似String的padEnd,但是該方法是限制和替代而不是補全。

用法:

limitText(str:string,limit:10,rep:".")

eg:

let str = "你好啊,想要去那里,我想去一個好地方"
limitText(str)//=>你好啊,想要去...
htmlEscap

對輸入的文字進行轉(zhuǎn)義防止注入攻擊的函數(shù)

deepClone

深層復制一個對象
雖然現(xiàn)在已經(jīng)有了Object.assign這樣的原生方法,但是有些地方還是要用到自己寫的。

用法:

deepClone(obj|array)//=>新的 obj|array

該方法不會拷貝原型的屬性。

addThrottle

對元素的某個對象的事件添加節(jié)流閥
使用方法:

addThrottle({el, event, handler, model?=0, threshold?=250})

參數(shù):

el:element對象

event:事件名稱

handler:監(jiān)聽器處理函數(shù)默認參數(shù)為e即事件對象

model: 節(jié)流閥的模式,0為間隔模式(每次停止時再執(zhí)行),1為頻率模式(比如threshold為250,則每秒發(fā)生4次。)

threshold?:可選的臨界值,數(shù)字,默認是250(目前是指定事件發(fā)生的間隔)

如果移除這個監(jiān)聽的話直接使用元素對象的removeEvnetListener(event:string)就行了。

checkType 方法有

isString

isNumber

isBoolean

isFunction

isNull

isUndefined

isObj

isArray

isDate

isRegExp

isSymbol

isPromise

isSet

isNaN

isFalse

isTrue

isIos

isPc

browserTypeIE11|Edge|FF|Opera|Safari|Chrome

CheckStr(str,type)常用驗證
type

phone 手機

tel 座機

card 身份證號

pwd 密碼/字母開頭長度6-18,只能包含字母數(shù)字下劃線

postal 郵政

email 郵箱

QQ qq號

URL 網(wǎng)址

money 小數(shù)點兩位金額

IP ip地址

date 日期

english 英文

chinese 中文

lower 小寫

upper 大寫

HTML html標簽

isCardID(sid) 嚴格身份證

parseTime

解析2018-12-12 12:12:12或者2018-12-12此類的文字為Date對象。

sortObj/sortObjArray

sortObj(舊)仍然可用,sorObjArray(新名字)。

sortObj/sortObjArray(
  arr:[obj], 
  property:string|[string|{[prope:string]:boolean}], 
  order:boolean = true, 
  isPromise:boolean=false
  ):[objSorted]

參數(shù):

arr:[obj] 對象數(shù)組,需要排序的目標

property:string|[string|{[prope:string]:boolean}] 要按排序的對象屬性名稱

order:string|boolen 排序的方向,true為從小到大s

isPromise:boolean = false 是否使用Promise模式,默認為false,注意,使用該參數(shù)時前面的order必須傳入。

使用場景

1 想要排列一個對象數(shù)組,條件是根據(jù)這些對象中的某個屬性。

var seed = [
  {name:"aaac",age: 12 },
  {name:"ecc",age: 12 },
  {name:"bccd",age: 12 },
  {name:"wds",age: 12 },
  {name:"esds",age: 12 },
  {name:"esds",age: 9},
];
// 根據(jù)名字從小到da排序
sortObjArrary(seed,"name")
// 根據(jù)名字從大到小排序
sortObjArrary(seed,"name",false)

2 還是排序上面的數(shù)據(jù),要求是,根據(jù)名字排序,如果名字相同則根據(jù)年齡排序

// 名字相同時根據(jù)年齡從小到大排序
sortObjArray(seed,["name","age"])
// 或者
sortObjArray(seed,["name",{age:true}])
// 名字相同時根據(jù)年齡從大到小排序
sortObjArray(seed,["name",{age:false}])

返回排序后的新的數(shù)組

對于對象數(shù)組根據(jù)其屬性進行排序的方法

download(url:string)

下載文件

createDom(template:string)

創(chuàng)建dom

createRandowWrods(length:number=15)

生成指定長度的文字,最低為5個

clipFileExts(filename:string,keepDot:boolean=false)

截取文件的后綴名
filename:文件名字
keepDot:是否保持點".",默認為false

wxHttp

小程序請求,結(jié)合promise使用axios風格

interface $request {
  (url: string | anyObj | $reqSet, config?: anyObj): Promise
  get?(url: string, config?: any): Promise
  post?(url: string, data?: anyObj, config?: any): Promise
  put?(url: string, data?: anyObj, config?: any): Promise
  head?(url: string, config?: any): Promise
  options?(url: string, config?: any): Promise
  delete?(url: string, config?: any): Promise
  interceptors?: {
    request: { use(a: $interRequest, b?: $interRequesError): any },
    response: { use(handle: $interResponse): any }
  }
  [name: string]: any
}
wxStore2

小程序中store2風格的本地存儲

interface wxStore2 {
  (key?: any, data?: any): Promise | void
  get(key: string): any
  set(key: string, data: any): any
  transact(key: string, data: Function): any
  clear(): void
  has(key: string): boolean
  remove(key: string): any
  getAll(): anyObj
  add(key: string, data: any): any
  keys(): any
  size(): number
  clearAll(): void
  isPromise: boolean
  nameSpace: string | undefined
  create(): $store2
}
camelToUnderline 駝峰轉(zhuǎn)下劃線
camelToUnderline(str:string,sperator?="_"):string
underlineToCamel 下劃線轉(zhuǎn)駝峰
underlineToCamel(str:string):string
樣式

新整理了樣式關(guān)系

base-config.styl

基礎的設置,如顏色尺寸什么的。

theme.styl

風格主題

lib.styl

主要是一些函數(shù)

mixins.styl

mixin的一些樣式

reset.styl

瀏覽器樣式重置

index.styl

包含上述所有

libmix.styl

包含上述除了reset.stylindex.styl之外的所有。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/97721.html

相關(guān)文章

  • 常用前端知識積累

    摘要:閉包的理解使用閉包主要是為了設計私有的方法和變量。只在中存放不敏感數(shù)據(jù),即使被盜也不會有重大損失。每個最多只能有條,每個長度不能超過,否則會被截掉。有些狀態(tài)不可能保存在客戶端。例如,為了防止重復提交表單,我們需要在服務器端保存一個計數(shù)器。 閉包的理解 使用閉包主要是為了設計私有的方法和變量。 優(yōu)點是可以避免全局變量的污染, 缺點是閉包會常駐內(nèi)存,會增大內(nèi)存使用量,使用不當很容易造成內(nèi)存...

    B0B0 評論0 收藏0
  • 常用前端知識積累

    摘要:閉包的理解使用閉包主要是為了設計私有的方法和變量。只在中存放不敏感數(shù)據(jù),即使被盜也不會有重大損失。每個最多只能有條,每個長度不能超過,否則會被截掉。有些狀態(tài)不可能保存在客戶端。例如,為了防止重復提交表單,我們需要在服務器端保存一個計數(shù)器。 閉包的理解 使用閉包主要是為了設計私有的方法和變量。 優(yōu)點是可以避免全局變量的污染, 缺點是閉包會常駐內(nèi)存,會增大內(nèi)存使用量,使用不當很容易造成內(nèi)存...

    haobowd 評論0 收藏0
  • 常用前端知識積累

    摘要:閉包的理解使用閉包主要是為了設計私有的方法和變量。只在中存放不敏感數(shù)據(jù),即使被盜也不會有重大損失。每個最多只能有條,每個長度不能超過,否則會被截掉。有些狀態(tài)不可能保存在客戶端。例如,為了防止重復提交表單,我們需要在服務器端保存一個計數(shù)器。 閉包的理解 使用閉包主要是為了設計私有的方法和變量。 優(yōu)點是可以避免全局變量的污染, 缺點是閉包會常駐內(nèi)存,會增大內(nèi)存使用量,使用不當很容易造成內(nèi)存...

    _Dreams 評論0 收藏0
  • 前端常用屬性/方法/命令積累

    摘要:定義表格中的表注內(nèi)容腳注樣式節(jié)標簽描述屬性定義文檔的樣式信息。原始值是由從對象下來的所有對象繼承的。方法通常由在后臺自動進行調(diào)用,而不是顯式地處于代碼中。 HTML常用標簽 其實在w3school上都有詳細的總結(jié)和描述,寫在這里是為了理清自己的思路,整理比較常用的標簽。原地址:http://www.w3school.com.cn/ta... //tag 基礎...

    wupengyu 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<