Maison > interface Web > tutoriel HTML > le corps du texte

Opérations JavaScript couramment utilisées sur le front-end (exemples de code)

云罗郡主
Libérer: 2018-10-17 15:05:48
avant
2422 Les gens l'ont consulté

Le contenu de cet article concerne les opérations JavaScript couramment utilisées (exemples de code) sur le front-end. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.

1. Supprimez un caractère spécifié dans la chaîne

Exemple : supprimez km dans "10km"

var str = "10km"

//方法一:
var res = str.replace('km', '')

//方法二:
var res = str.split('km').join('')
//join方法不传参默认使用逗号作为分隔符
Copier après la connexion

2. >

Pièce jointe : Utilisation de Array.from() :
var arr = [1, 2, 3, 1, 2]

//方法一:
var res = [...new Set(arr)]

//方法二:
var res = Array.from(new Set(arr))

//方法三:
var res = [];
for (var i in arr) {
	if (res.indexOf(arr[i] === -1) {
		res.push(arr[i])
	}
}

//方法四:
var res = []
arr.map((item, index) => {
	if (res.indexOf(item) === -1){
		res.push(item)
	}
})
Copier après la connexion

Array.from(arr, mapfn, thisArg) : utilisé pour convertir deux types d'objets en de vrais tableaux.

    Objet de type tableau (doit avoir un attribut de longueur)
  1. Objet traversable (chaîne avec interface Iterator déployée, nouveau dans ES6 Map and Set) .
  2. Paramètres : Le premier est un tableau, qui doit être passé ; le second est une fonction (similaire à la fonction map), qui opère sur les éléments du tableau puis renvoie le tableau, facultatif ; le troisième Le premier est un pointeur vers le mot-clé this, facultatif.

3. Convertir un objet pseudo-tableau en tableau
var obj1 = {
	0: 'a',
	1: 'b',
	2: 'c'
}
var arr1 = Array.from(obj1)
console.log(arr1) // []

/* 1. 类数组对象,具有length属性,而普通对象是没有length属性的。*/
/* 2. 类数组对象的属性名必须为非负整数,对象中的属性名会被当做字符串处理。*/

var obj2 = { 
	0: 'a',
	1: 'b',
	2: 'c',
	length: 2
}
var arr2 = Array.from(obj2)
console.log(arr2) // ["a", "b"]

var obj3 = {
	0: 'a',
	1: 'b',
	2: 'c',
	length: 4
}
var arr3 = Array.from(obj3)
console.log(arr3) // ["a", "b", "c", undefined]

var obj4 = {
	0: 'a',
	1: 'b',
	2: 'c',
	length: 3
}
var arr4 = Array.from(obj4, item => item + 1)
console.log(arr4) // ["a1", "b1", "c1"]

var obj5 = {
	"1": "a",
	"0": "b",
	length: 2
}
var arr5 = Array.from(obj5)
console.log(arr5) // ["b", "a"]
Copier après la connexion

4. Copie approfondie d'un tableau ou d'un objet
var obj = {
	0: 'a',
	1: 'b',
	length: 2
}
//方法一:
Array.from(obj)

//方法二:
Array.prototype.slice.call(obj) 

//方法三:
Array.prototype.concat.apply([], obj)

//方法四:
Array.prototype.splice.call(obj, 0) // 返回被删除的元素,原对象obj会被破坏掉
console.log(obj) // obj: {length: 0}

// 上述的Array.prototype 均可用[]代替
Copier après la connexion

5. Les domaines d'effet font que les variables internes remplacent les variables externes.
//方法一:
JSON.parse(JSON.stringify(obj))

//方法二:递归遍历
function clone (obj) {
  var res = obj.constructor === Array ? [] : {}
  for (var i in obj) {
    res[i] = typeof obj[i] === 'object' ? clone(obj[i]) : obj[i] // 即obj[i]为数组或对象,继续拷贝
  }
  return res
}

//附:数组浅拷贝
var arr = ['a', ['b', ['c']]]

//1.使用slice()
var res = arr.slice(0)
console.log(res) // ['a', ['b', ['c']]]
res[1][1] = 'b'
console.log(res) // ['a', ['b', ['b']]]
console.log(arr) // ['a', ['b', ['b']]]

//2.使用concat()
var arr = ['a', ['b', ['c']]]

var res = [].concat(arr)
res[1][1] = 'b'
console.log(res) // ['a', ['b', ['b']]]
console.log(arr) // ['a', ['b', ['b']]]

//Object.assign()也只能实现对象的浅拷贝,它只是一级属性复制,比浅拷贝多深拷贝了一层
var obj = {a: "a", b: {c: "d"}}
var res = Object.assign({}, obj)
res.b.c= "e"
console.log(res) // {a: "a", b: {c: "e"}}
console.log(obj) // {a: "a", b: {c: "e"}}
Copier après la connexion

6. Utilisation des modèles de balises dans ES6 :
var date = new Date().getDate();
function f(){
	console.log(date);
	if(false){
	    var date = 0;//变量提升
   }
}
f();//undefined
Copier après la connexion

Ce qui précède est l'introduction complète, si vous souhaitez en savoir plus sur le
let a = 1;
let b = 2;
function tag(arr, value1, value2){
    console.log(arr); //["hello ", " world ", ""]
    console.log(value1); //3
    console.log(value2); //2
}
tag`hello ${a + b} world ${a * b}`;
/**
如果函数名后的模板字符串中没有变量,则直接将其作为函数参数调用。
如果存在变量则先将模板字符串处理成多个参数,再调用函数。

处理规则:
1.默认该函数第一个参数为数组,该数组的成员是模板字符串中那些没有变量替换的部分。
2.变量替换只发生在数组的第一个成员与第二个成员之间、第二个成员与第三个成员之间。
以此类推,故arr中第三个成员为"",原因是${a * b}的变量替换发生在第二个成员与第三个成员之间,
所以必须存在第三个成员。
3.函数的其他参数,都是模板字符串各个变量被替换后的值。

函数形如:
function tag(stringArr, ...value){}
*/
Copier après la connexion

tutoriel vidéo HTML. , veuillez faire attention au site Web PHP chinois.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:csdn.net
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal