Js的一些工具方法
阿新 • • 發佈:2020-09-10
Js獲取父級,兄弟,子元素
// 獲取子節點 document.getElementById("div").childNodes // 獲取子元素 document.getElementById("div").children[0] // 第一個子元素 document.getElementById("div").firstChild // 最後一個 document.getElementById("div").lastChild // 父元素 document.getElementById("div").parentNode // 所有的父節點 document.getElementById("div").offsetParent // 所有的兄弟元素 document.getElementById("div").parentNode.children // 上一個兄弟元素 document.getElementById("div").previousSibling // 下一個兄弟元素 document.getElementById("div").nextSibling
NodeJs 格式化字串
- %s - String 將用於轉換除 BigInt、 Object 和 -0 外的所有值。BigInt 值將用 n 表示,而沒有使用者定義 toString 函式的物件使用帶有選項 { depth: 0, colors: false, compact: 3 } 的 util.inspect() 進行檢查。
- %d - Number 將用於轉換除 BigInt 和 Symbol 之外的所有值。
- %i - parseInt(value, 10) 用於除 BigInt 和 Symbol 之外的所有值。
- %f - parseFloat(value) 用於除 BigInt 和 Symbol 之外的所有值。
- %j - JSON。如果引數包含迴圈引用,則替換為字串 '[Circular]'。
- %o - Object。具有通用 JavaScript 物件格式的物件的字串表示形式。 類似於帶有選項 { showHidden: true, showProxy: true } 的 util.inspect()。 這將顯示完整物件,包括非可列舉屬性和代理。
- %O - Object。具有通用 JavaScript 物件格式的物件的字串表示形式。 類似於 util.inspect() 但沒有選項。 這將顯示完整物件,不包括非可列舉屬性和代理。
- %c - CSS。該說明符會被忽略,將會跳過任何傳入的 CSS。
- %% - 單個百分號('%')。這不會消耗引數。
const util = require('util');
util.format('%s:%s', 'foo');
NodeJs Md5 加密
const crypto = require("crypto")
const getMd5 = (url) => crypto.createHash("md5").update(url).digest("hex");
console.log(getMd5("1234"))
JavaScript 時間格式化
// 時間格式化 new Date().format("yyyy-MM-dd hh:mm:ss")
Date.prototype.format = function(fmt) {
var o = {
"M+" : this.getMonth()+1, //月份
"d+" : this.getDate(), //日
"h+" : this.getHours(), //小時
"m+" : this.getMinutes(), //分
"s+" : this.getSeconds(), //秒
"q+" : Math.floor((this.getMonth()+3)/3), //季度
"S" : this.getMilliseconds() //毫秒
};
if(/(y+)/.test(fmt)) {
fmt=fmt.replace(RegExp.$1, (this.getFullYear()+"").substr(4 - RegExp.$1.length));
}
for(var k in o) {
if(new RegExp("("+ k +")").test(fmt)){
fmt = fmt.replace(RegExp.$1, (RegExp.$1.length==1) ? (o[k]) : (("00"+ o[k]).substr((""+ o[k]).length)));
}
}
return fmt;
}