前端相關免查整合-vue、es、工具類等

知識

工具篇

網頁

取色器

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>

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/161160.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/161160.shtml
英文地址,請注明出處:http://en.pswp.cn/news/161160.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

SEO從業人員提問常用的ChatGPT通用提示詞模板

如何提高網站在搜索引擎中的排名&#xff1f; 如何評估網站的SEO效果和優化潛力&#xff1f; 如何運用關鍵詞研究和競爭對手分析來制定SEO策略&#xff1f; 如何優化網站的內容、結構和元數據來提高SEO效果&#xff1f; 如何運用外部和內部鏈接來提高網站的權威性和排名&am…

OpenCvSharp從入門到實踐-(02)圖像處理的基本操作

目錄 圖像處理的基礎操作 1、讀取圖像 1.1、讀取當前目錄下的圖像 2、顯示圖像 2.1、Cv2.ImShow 用于顯示圖像。 2.2、Cv2.WaitKey方法用于等待用戶按下鍵盤上按鍵的時間。 2.3、Cv2.DestroyAllWindows方法用于銷毀所有正在顯示圖像的窗口。 2.4實例1-顯示圖像 2.4實例…

分類預測 | Matlab實現KPCA-IDBO-LSSVM基于核主成分分析-改進蜣螂算法優化最小二乘支持向量機的分類預測

分類預測 | Matlab實現KPCA-IDBO-LSSVM基于核主成分分析-改進蜣螂算法優化最小二乘支持向量機的分類預測 目錄 分類預測 | Matlab實現KPCA-IDBO-LSSVM基于核主成分分析-改進蜣螂算法優化最小二乘支持向量機的分類預測分類效果基本描述程序設計參考資料 分類效果 基本描述 1.多特…

校園圈子論壇,交友,帖子內短視頻,二手市場,APP小程序H5三端交付,源碼交付,支持二開

校園圈子論壇&#xff0c;交友頻道&#xff0c;商城&#xff0c;二手市場&#xff0c;活動專區&#xff0c;短視頻&#xff0c;從校園生活的方方面面展現出了充滿活力和創造力的鏡頭。這個頻道是一個讓學生們相互交流、結識新朋友的平臺&#xff0c;不僅有交友功能&#xff0c;…

【done+重點】劍指Offer56-I:找出數組中2個只出現1次的整數

力扣&#xff0c;https://leetcode.cn/problems/shu-zu-zhong-shu-zi-chu-xian-de-ci-shu-lcof/description/ 題目&#xff1a;一個整型數組nums里除兩個數字之外&#xff0c;其他數字都出現了兩次。請寫程序找出這兩個只出現一次的數字。要求時間復雜度是O(n)&#xff0c;空間…

啟動Dubbo項目注冊Zookeeper時提示zookeeper not connected異常原理解析

原創/朱季謙 遇到一個很詭異的問題&#xff0c;我在啟動多個配置相同zookeeper的Dubbo項目時&#xff0c;其他項目都是正常啟動&#xff0c;唯獨有一個項目在啟動過程中&#xff0c;Dubbo注冊zookeeper協議時&#xff0c;竟然出現了這樣的異常提示—— Caused by: java.lang.…

OpenAI再次與Sam Altman談判;ChatGPT Voice正式上線

11月22日&#xff0c;金融時報消息&#xff0c;OpenAI迫于超過700名員工聯名信的壓力&#xff0c;再次啟動了與Sam Altman的談判&#xff0c;希望他回歸董事會。 在Sam確定加入微軟后&#xff0c;OpenAI超700名員工簽署了一封聯名信&#xff0c;要求Sam和Greg Brockman&#x…

【尚硅谷】第06章:隨堂復習與企業真題(面向對象-基礎)

第06章&#xff1a;隨堂復習與企業真題&#xff08;面向對象-基礎&#xff09; 一、隨堂復習 1. &#xff08;了解&#xff09;面向過程 vs 面向對象 不管是面向過程、面向對象&#xff0c;都是程序設計的思路。面向過程&#xff1a;以函數為基本單位&#xff0c;適合解決簡單…

解決ElementUI時間選擇器回顯出現Wed..2013..中國標準時間.

使用餓了么組件 時間日期選擇框回顯到頁面為啥是這樣的&#xff1f; 為什么再時間框中選擇日期&#xff0c;回顯頁面出現了這種英文格式呢&#xff1f;&#xff1f;&#xff1f;&#xff1f; 其實這個問題直接使用elementui的內置屬性就能解決 DateTimePicker 日期時間選擇…

程序員指南六:數據平面開發套件

PORT HOTPLUG FRAMEWORK 端口熱插拔框架為DPDK應用程序提供在運行時附加和分離端口的能力。由于該框架依賴于PMD實現&#xff0c;PMD無法處理的端口超出了該框架的范圍。此外&#xff0c;在從DPDK應用程序分離端口后&#xff0c;該框架不提供從系統中移除設備的方法。對于由物…

微信開發:API接口與ipad協議的深度比較及最佳選擇

微信開發&#xff1a;API接口與ipad協議的深度比較及最佳選擇 在深入探索微信開發的過程中&#xff0c;理解不同API接口和協議的特點以及他們的適用場景是非常重要的。本文將詳細對比幾種主流的微信API接口和協議&#xff0c;包括Web版微信協議、iPad協議、PC微信協議/Mac協議…

opencv-圖像梯度

目標 ? 圖像梯度&#xff0c;圖像邊界等 ? 使用到的函數有&#xff1a;cv2.Sobel()&#xff0c;cv2.Schar()&#xff0c;cv2.Laplacian() 等 原理 梯度簡單來說就是求導。 OpenCV 提供了三種不同的梯度濾波器&#xff0c;或者說高通濾波器&#xff1a;Sobel&#xff0c;Schar…

萬界星空科技QMS質量管理系統介紹

QMS&#xff08;Quality Management System&#xff09;質量管理系統是五大基礎系統之一&#xff0c;在工業企業中被廣泛的應用&#xff0c;在質量策劃、生產過程質量監督、體系審核和文檔管理等業務上發揮著不可替代的作用。 一般制造業工廠現狀&#xff1a;質量成本高&#x…

使用 COPY 加速 PostgreSQL 批量插入

文章目錄 1.copy命令介紹2.copy vs insert的優勢3.測量性能4.結論 1.copy命令介紹 PostgreSQL 中的命令COPY是執行批量插入和數據遷移的強大工具。它允許快速有效地將大量數據插入表中。 COPY命令為批量插入和數據遷移提供了更簡單且更具成本效益的解決方案。 可以避免使用諸…

基于SSM的課程資源管理系統

末尾獲取源碼 開發語言&#xff1a;Java Java開發工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;采用JSP技術開發 數據庫&#xff1a;MySQL5.7和Navicat管理工具結合 服務器&#xff1a;Tomcat8.5 開發軟件&#xff1a;IDEA / Eclipse 是否Maven項目&#x…

電力感知邊緣計算網關產品設計方案-網關系統通信架構方案

1.邊緣協同控制模發 能針對建筑、充電樁、分布式儲能、分布式光伏等典型設備建立對應物模型、完成數據采集通信協議設計和控制指令交互設計,能針對建筑、充換電站等典型場景提出具體實施方案和人工智能控制算法和邏輯。物模型、通信協議設計和控制指令交互設計科學、先進,能…

聚類系列(一)——什么是聚類?

目前在做聚類方面的科研工作, 看了很多相關的論文, 也做了一些工作, 于是想出個聚類系列記錄一下, 主要包括聚類的概念和相關定義、現有常用聚類算法、聚類相似性度量指標、聚類評價指標、 聚類的應用場景以及共享一些聚類的開源代碼 下面正式進入該系列的第一個部分&#xff…

webpack打包三方庫直接在html里面使用

場景&#xff1a;我是小程序中使用wxmp-rsa庫進行加密&#xff0c;然后在html里面解密 我就想把wxmp-rsa庫打包到一個js里面&#xff0c;然后在html里面直接引入使用。 webpack配置 const path require("path"); const MiniCssExtractPlugin require("mini-…

【MybatisPlus】簡介與使用

MyBatisPlus 1.簡介 MyBatisPlus&#xff08;簡稱MP&#xff09;是一個MyBatis的增強工具&#xff0c;在MyBatis的基礎上只做增強不做改變&#xff0c;為簡化開發、提高效率而生 官網&#xff1a;https://baomidou.com/ MyBatis-Plus特性&#xff1a; 無侵入&#xff1a;只…

C_1練習題

一、單項選擇題(本大題共20小題,每小題2分,共40分。在每小題給出的四個備選項中,選出一個正確的答案&#xff0c;并將所選項前的字母填寫在答題紙的相應位置上。) 若 x 為int 型變量,則執行以下語句后,x的值為(&#xff09; x5; xx*x; A. 25 B.-20 C. 20 D.-25 若x、i、j、k都…