知識
工具篇
網頁
取色器
F12 之后, style里面選一個顏色,然后點擊鉛筆,復制值
dayjs
用法
const date = dayjs('2021-09-01');
const formattedDate = dayjs('2021-09-01').format('YYYY-MM-DD');
console.log(formattedDate); // 輸出:2021-09-01
常用
刷新頁面
router.go(0)
location.reload()
TS篇
數據類型定義
基本類型
類型包含:
布爾類型 boolean
數字類型 number
字符串類型 string
數組類型 array
元組類型 tuple
枚舉類型 enum
任意類型 any
null 和 undefined
void類型
never類型
let title = '張三'
let age = 18
let loading = true
let obj = null
let total = undefined# 帶類型限制
let title:string = '張三'
let age:number = 18
let loading:boolean = true
let obj:null = null
let total:undefined = undefined# 多種類型
let title:number|string = 18
引用類型
數組
# 數組
let arr = [1, 2, 3]# 帶類型
let arr:number = [1, 2, 3]
let arr:Array<number> = [1, 2, 3]# 已知數組的長度和類型:在TS中稱為元組類型
let arr: [string, number] = ['張三', 18]
數組操作
基礎操作:shift:刪除原數組第一項,并返回刪除元素的值;如果數組為空則返回undefined
var a = [1,2,3,4,5];
var b = a.shift(); //a:[2,3,4,5] b:1unshift:將參數添加到原數組開頭,并返回數組的長度
var a = [1,2,3,4,5];
var b = a.unshift(-2,-1); //a:[-2,-1,1,2,3,4,5] b:7
(IE6.0下測試返回值總為undefined,FF2.0下測試返回值為7,所以這個方法的返回值不可靠,需要用返回值時可用splice代替本方法來使用。)pop:刪除原數組最后一項,并返回刪除元素的值;如果數組為空則返回undefined
var a = [1,2,3,4,5];
var b = a.pop(); //a:[1,2,3,4] b:5push:將參數添加到原數組末尾,并返回數組的長度
var a = [1,2,3,4,5];
var b = a.push(6,7); //a:[1,2,3,4,5,6,7] b:7concat()可以將兩個數組合并在一起,如果是使用ES6語法也可以用擴展運算符…來代替
var a = [1,2,3,4,5];
var b = a.concat(6,7); //a:[1,2,3,4,5] b:[1,2,3,4,5,6,7]splice(start,deleteCount,val1,val2,…):從start位置開始刪除deleteCount項,并從該位置起插入
var a = [1,2,3,4,5];
var b = a.splice(2,2,7,8,9); //a:[1,2,7,8,9,5] b:[3,4]
var b = a.splice(0,1); //同shift
a.splice(0,0,-2,-1); var b = a.length; //同unshift
var b = a.splice(a.length-1,1); //同pop
a.splice(a.length,0,6,7); var b = a.length; //同pushreverse:將數組反序
var a = [1,2,3,4,5];
var b = a.reverse(); //a:[5,4,3,2,1] b:[5,4,3,2,1]sort(orderfunction):按指定的參數對數組進行排序
var a = [1,2,3,4,5];
var b = a.sort(); //a:[1,2,3,4,5] b:[1,2,3,4,5]slice(start,end):可以截取出數組某部份的元素為一個新的數組,有兩個必填的參數,第一個是起始位置,第二個是結束位置( 操作時數字減1 )
var a = [1,2,3,4,5];
var b = a.slice(2,5); //a:[1,2,3,4,5] b:[3,4,5]join(separator):將數組的元素組起一個字符串,以separator為分隔符,省略的話則用默認用逗號為分隔符
var a = [1,2,3,4,5];
var b = a.join("|"); //a:[1,2,3,4,5] b:"1|2|3|4|5"let a = [1,2,3,4,5,6,7,8];
console.log(a.join()); // 1,2,3,4,5,6,7,8
console.log(a.join('')); // 12345678
console.log(a.join('@@'));
// 1@@2@@3@@4@@5@@6@@7@@8.Array和Object的特性
//Array:
/*新建:*/var ary = new Array(); 或 var ary = [];
/*增加:*/ary.push(value);
/*刪除:*/delete ary[n];
/*遍歷:*/for ( var i=0 ; i < ary.length ; ++i ) ary[i];
//Object:
/*新建:*/var obj = new Object(); 或 var obj = {};
/*增加:*/obj[key] = value; (key為string)
/*刪除:*/delete obj[key];
/*遍歷:*/for ( var key in obj ) obj[key];
Object完全可以作為一個集合來使用(1)如果我們要在Array中檢索出一個指定的值,我們需要遍歷整個數組: var keyword = ;for ( var i=0 ; i < ary.length ; ++i ){if ( ary[i] == keyword ){// todo}
}
(2)在Object中檢索一個指定的key的條目,只需要是要使用:var key = '';var value = obj[key];
// todo
copyWithin()
從數組的指定位置拷貝元素到數組的另一個指定位置中。
filter()
- filter()會將數組中的「每一個」元素帶入指定的函數內做判斷,如果元素符合判斷條件則會返回,組成一個新的數組。
let a = [1,2,3,4,5,6,7,8];
console.log(a.filter(e => e > 3));
// [4, 5, 6, 7, 8]
console.log(a.filter(e => e%2 == 0));
// [2, 4, 6, 8]
find()
- find()會將數組中的「每一個」元素帶入指定的函數內做判斷,并會返回第一個符合判斷條件的元素,如果沒有元素符合則會返回undefined。
let a = [1,2,3,4,5,6,7,8];
console.log(a.find(e => e > 3)); // 4
console.log(a.find(e => e < 0)); // undefined
forEach()
- forEach()會將數組中每個元素套用到指定的函數里進行運算,函數有三個參數,第一個參數表示每個元素的值( 必填),第二個參數為該元素的索引值( 選填),第三個參數則表示原本的數組( 選填)。
let a = [1,2,3,4,5];
let b = 0;
a.forEach(item => {b = b + item;
});
console.log(b); // 15 ( 1+2+3+4+5 )
如果結合第二和第三個參數進行搭配使用,就能做到改變原本數組的效果。let a = [1,2,3,4,5];
a.forEach((item, index, arr) => {arr[index] = item * 10;
});
console.log(a); // [10,20,30,40,50]
includes()
判斷一個數組是否包含一個指定的值
let a = [1,2,3,4,5,6,7,8];
console.log(a.includes(2));
// true
console.log(a.includes(2,2));
// false ( 在 3,4,5,6,7,8 查找有沒有 2 )
indexOf()lastIndexOf()
- indexOf()會判斷數組中是否包含某個值,判斷的方式為「由左而右」,如果有包含就返回這個值在數組中的索引值,如果沒有就返回-1,有兩個參數,第一個參數表示要判斷的值( 必填),第二個參數表示從數組的哪個位置開始判斷( 選填,預設為0 )。
let a = [1,2,3,4,5,6,7,8];
console.log(a.indexOf(4)); // 3
console.log(a.indexOf(4,5));
// -1 ( 在6,7,8中搜索有沒有4 )
lastIndexOf()會判斷數組中是否包含某個值,判斷的方式為「由右而左」,如果有包含就返回這個值在數組中的索引值,如果沒有就返回-1,這個方法有兩個參數,第一個參數表示要判斷的值( 必填),第二個參數表示判斷從數組的哪個位置開始從右往左查找( 選填,默認為整個數組長度-1 )。
let a = [1,2,3,4,5,6,7,8];
console.log(a.lastIndexOf(3)); // 2
console.log(a.lastIndexOf(3,1));
// -1 ( 只在1,2中判斷,所以沒有 3 )
some()[s?m]
檢測數組元素中是否有元素符合指定條件
- some()會將數組中的「每一個」元素帶入指定的函數內做判斷,只要有任何一個元素符合判斷條件,就會返回true,如果全都不符合,才會返回false。
let a = [1,2,3,4,5,6];
console.log(a.some(e => e > 3));
// 返回 true,因為 4、5、6 大于 3
console.log(a.some(e => e > 6));
// 返回 fasle,因為全都小于或等于 6
fill()
- fill()會把數組中所有元素,置換為指定的值,fill()有三個參數,第一個是準備要置換的內容(必填),第二個是從什么位置開始置換(選填,不設定就全部置換) ,第三個是停止置換的元素的前一個位置(選填,預設等于數組長度)。
let a = [1,2,3,4,5,6,7,8];
a.fill('a');
console.log(a); // ['a','a','a','a','a','a','a','a']
let b = [1,2,3,4,5,6,7,8];
b.fill('b',3,5);
console.log(b); // [1,2,3,'b','b',6,7,8]
length()
- length可以取得數組的長度。
let a = [1,2,3,4,5,6,7,8];
console.log(a.length); // 8
findIndex()
- findIndex()會將數組中的「每一個」元素帶入指定的函數內做判斷,并會返回第一個符合判斷條件元素的位置索引,如果沒有元素符合則會返回-1。
let a = [1,2,3,4,5,6,7,8];
console.log(a.findIndex(e => e > 3)); // 3
console.log(a.findIndex(e => e < 0)); // -1
reduce()、reduceRight()
reduce()可以將數組中每個元素進行計算,每次計算的結果會再與下個元素作計算,直到結束為止,里頭包含一個函數( 必填) 和初始計算的數值( 選填),函數內有四個參數,第一個是計算的值( 必填),第二個是取得的元素(必填),第三個是該元素的索引值( 選填),第四個是原本的數組(選填)。
let a = [1,2,3,4,5,6,7,8];
let b = a.reduce(function(total, e){return total + e;
});
console.log(b); // 36 ( 1+2+3+4+5+6+7+8=36 )
flat()
- flat()可以將一個多維數組的深度轉成一維(扁平化或稱作降維),它有一個選填的參數,代表要轉換的深度數字,預設為1(只展開一層放到一維數組里,如果是2,只展開2層放到一維數組里),如果深度有很多層,可使用Infinity來全部展開成一維數組。
let a = [1,2,[3],[4,[5,[6]]]];
let b = a.flat();
let c = a.flat(2);
let d = a.flat(Infinity);
console.log(b); // [1, 2, 3, 4, [5, [6]]]
console.log(c); // [1, 2, 3, 4, 5, [6]]
console.log(d); // [1, 2, 3, 4, 5, 6]
flatMap()
- flatMap()的方法等于map()和flat()的組合,在運算后直接將數組扁平化處理。
let a = [1,2,[3],[4,5]];
let b = a.flatMap(e => e+1);
let c = a.map(e => e+1).flat();
console.log(b);
// [2, 3, "31", "4,51"] ( 可以看到 b 和 c 得到的結果相同 )
console.log(c);
// [2, 3, "31", "4,51"]
Array.isArray()
- Array.isArray()能判斷一個元素是否為數組,如果是就返回true,不然就返回false。
let a = [1,2,3,4,5,6,7,8];
let b = 123;
let c = 'hello';
let d = {d1:1,d2:2};
console.log(Array.isArray(a)); // true
console.log(Array.isArray(b)); // false
console.log(Array.isArray(c)); // false
console.log(Array.isArray(d)); // false
Array.from()
Array.from()會將「類數組」或是「可迭代的對象」轉換成數組,Array.from()有兩個參數,第一個參數為「類數組對象」或「可迭代的對象」(必填),第二個參數則是改變轉換成數組元素的函數(選填)。
類數組對象具有length 屬性以及索引化index 的元素,可迭代對象表示具有可以利用迭代的方式取得它自己本身的元素,例如Map 和Set…等。( 參考MDN 說法 )
let a = 'abcde';
let b = Array.from(a);
console.log(b); // ['a','b','c','d','e']
let c = Array.from(a, e => e + e);
console.log(c); // ['aa','bb','cc','dd','ee']
類數組對象寫法必須包含length 屬性,且對象的key須為0開始的數字,對應轉換后的元素索引。let a = {'0': 14,'2': 13,'1': 7,'3': 9,'4': 6,length: 5
};
let b = Array.from(a);
console.log(b); // [14,7,13,9,6]
Array.of()
- Array.of()可以快速將數字、字串等內容,轉換成數組。
let a = Array.of(1,'a',2,'b',3);
console.log(a);
// [1, "a", 2, "b", 3]
toString()
- toString()會把整個數組轉換成字符串。
let a = [1,2,3,4,5,6,7,8];
let b = a.toString();
console.log(b);
// 1,2,3,4,5,6,7,8
every()
- every()會將數組中的「每一個」元素帶入指定的函數內做判斷,只要有任何一個元素不符合判斷條件,會回返回false,如果全部符合,就會回傳true。
let a = [1,2,3,4,5,6];
console.log(a.every(e => e > 3));
// fasle ( 因為1、2 小于 3,3 等于 3 )
console.log(a.every(e => e > 0));
// true
keys()
- keys()會返回數組中的每一個索引值( key )成為一個新的Array Iterator對象,因為是Array Iterator對象,可以使用for…of進行迭代。
let a = ['a','b','c','d','e'];
let b = a.keys();
for (let key of b) {console.log(key); // 1、2、3、4、5
}
Object.keys({name:"123"})//["name"]
valueOf()
- valueOf()會返回數組的原始值,如果原本的數組有修改,那么返回的原始值也會跟著改變(相當淺復制)
let a = [1,2,3,4,5,6,7,8];
let b = a.valueOf();
console.log(a);
// [1, 2, 3, 4, 5, 6, 7, 8]
let c = a.valueOf();
a.shift();
console.log(a);
// [2, 3, 4, 5, 6, 7, 8]
console.log(b);
// [2, 3, 4, 5, 6, 7, 8] ( 因為 a 的原始值更新了,所以 b 也變了 )
console.log(c);
// [2, 3, 4, 5, 6, 7, 8]
map
et map:Map<string,number> = new Map();
// let map:Map<string,number> = new Map([["劉天悅",10],["王明",20]]);// 迭代map
for(let entry of map.entries()){console.log("entries1",entry[0], entry[1]);
}
for(let [key,value] of map.entries()) {console.log("entries2",key, value);
}// 遍歷map
map.forEach((value:number,key:string,map:Map<string,number>)=>{console.log("forEach",key,value);
});
Map
數組轉Map
const map = new Map(res.map(item =>[item.date, item]));
初始化
const initMap = new Map<string, dayScheduleBO>([["key1", {date: "string",details: Array<dayDetailBO>}]]
)
對象
let obj = {name: '張三',age: 18
}#帶類型interface Props {name: string,age: number
}let obj: Props = {name: '張三',age: 18
}console.log(obj)
實例化
注意class test {name: stringvalue?: string
}使用new 實例化,會帶可選屬性,值為undefined,
let a = new test()不想帶屬性,可用, 后續可再加值
let a = {name: 'aaa'
}
if(value){a.value = value
}
接口
interface Props {name: string,age: number,title?:string
}#問號和冒號表示該屬性可能有可能沒有
枚舉
enum Gender {BOY,GIRL
}console.log(Gender.BOY) // 0
console.log(Gender.GIRL) // 1#默認值
enum Gender {BOY = 1001,GIRL = 1002
}console.log(Gender.BOY) // 1001
console.log(Gender.GIRL) // 1002# 常數
const enum Gender {BOY,GIRL
}console.log(Gender.BOY) // 0
console.log(Gender.GIRL) // 1
任意類型
let todo:any = 'go home'
函數
#有返回值
function todo(a: number): number {return a
}#無返回值
function todo(a: number): void {console.log(a)
}#函數拋出錯誤,永遠不會執行完成(如死循環),使用never
function demo(): never {throw new Error('出錯了')
}## 泛型、傳參、返回值類型約定export function transformObjectToRoute<T = RouteItem>(routeList: RouteItemResponse[]): T[] {}
類型斷言
let a: number|string;
console.log(a.toFixed(2)) #錯誤let a:number|string;
console.log((a as number).toFixed(2))
console.log((<number>a).toFixed(2))
字面量
type Gender = 1 | 2;
let boy:Gender = 1;
let girl:Gender = 2;
文件下載
請求頭
要加 responseType: ‘blob’
export function downloadRecord(search: consumptionRecordSearch) {return request.post<basePageRes<consumptionRecord>>({url: API.RECORD_EXPORT_URL,data: search,responseType: 'blob'}, {isTransformResponse: false});
}
方法
const downloadImportTemplate = async () => {let response = await downloadTemplate();console.log('bb', response);const blob = new Blob([response], {type: 'application/vnd.ms-excel',});let link = document.createElement('a');link.href = URL.createObjectURL(blob);link.setAttribute('download', '人員模板文件.xlsx');link.click();
}
類型判斷
if(value){}if(!value){# 過濾 undefined 和空
}# 判斷 空字符串 / null / undefinedfunction isEmpty(str) {return (!str || 0 === str.length);}console.log(null == undefined);//true
console.log(null === undefined);//false
函數、方法
數組
map
Array.map() #有返回值,創建新數組
#定義
map(function(element, index, array) { /* ... */
}, thisArg) const mapNumbers = numbers.map(function(number) {return number * 2;
});
foreach
Array.forEach() #只遍歷
#定義
forEach(function(element, index, array) { /* ... */
}, thisArg) const numbers = [1, 2, 3, 4];numbers.forEach(function(number) {mapNumbers.push(number * 2);
});
filter
menuRouters.filter((v) => {return v.isTab || null == v.isTab;})
CSS篇
居中
text-align: center;.container {width: 300px; /* 設置容器的寬度 */margin: 0 auto; /* 水平居中 */
}.container {display: flex;justify-content: center; /* 水平居中 */align-items: center; /* 垂直居中 */
} .container {display: grid;place-items: center; /* 水平和垂直居中 */
}.container {position: absolute;left: 50%;transform: translateX(-50%);
}
按鈕居右
.button{
float:right;
}.button{
position:absolute;
right:0;
}.container{
position:relative;
}
.button{
position:absolute;
right:0;
top:50%;
transform: translateY(-50%);
}
邊距
padding-top:20px;上內邊距padding-right:30px;右內邊距padding-bottom:30px;下內邊距padding-left:20px;左內邊距padding:1px四邊統一內邊距padding:1px1px上下,左右內邊距padding:1px1px1px上,左右,下內邊距padding:1px1px1px1px上,右,下,左內邊距
透明度
CSS透明度是指網頁中元素的不透明度程度。在CSS中,可以使用opacity屬性來設置元素的透明度,取值范圍為0到1,其中0表示完全透明,1表示完全不透明。除了opacity屬性外,還可以使用rgba()函數來設置元素的背景顏色透明度,其中最后一個參數表示透明度,取值范圍也是0到1。例如,background:rgba(255,0,0,0.5) 表示設置元素的背景顏色為紅色,透明度為50%。12
VUE篇
vue3
組件通信
子傳遞父
子
const emit = defineEmits(['manage-product', 'delete-item']);emit('manage-note', note);父
@delete-item="handleDeleteItem"
事件
父傳遞子
子 const props = defineProps({type: String,
});父<tab-table type='ADD'></tab-table>
組件之間
倉庫
export const useUserStore = defineStore('user', {})import { useSettingStore, useUserStore } from '@/store';const user = useUserStore();user....
字符串拼接
:class="[ 'string' + index, 'string2' ]":action=" path + 'string' ":class="{ red : index == 2 , [ 'layout' + index ] : true }"
路由
傳參
router.push('/detail/base?id=' + props.note.id);router.push({path: '/ab/c',query: {id :1}});router.push({path: `/ab/c/${props.note.id}`,});
獲取
import { useRoute, useRouter } from 'vue-router';
const route = useRoute();const id = route.query.id;
路由跳轉
import { useRouter } from 'vue-router';
const router = useRouter();
router.push('/detail/base');
倉庫
倉庫取值
import { useUserStore } from '@/store';const userStore = useUserStore();
const { token } = userStore;
刷新頁面
router.go(0)
插槽
寫法
v-slot 其簡寫形式為 #父組件在引入指定插槽時候,template指定插槽時必須使用 v-slot ,
<template #c><h1>插槽c 內容1</h1><h1>插槽c 內容2</h1></template>