19 techniques de raccourci utiles pour JavaScript
Jan 03, 2018 pm 02:56 PM
javascript
js
分享
Cet article partage principalement avec vous 19 techniques d'abréviation JavaScript utiles, dans l'espoir d'aider tout le monde.
1. Opérateur ternaire
Lorsque vous souhaitez écrire une instruction if...else, utilisez plutôt l'opérateur ternaire.
1
<span style=
"font-size: 16px;"
>
const
x = 20;<br>let answer;<br>
if
(x > 10) {<br> answer =
'is greater'
;<br>}
else
{<br> answer =
'is lesser'
;<br>}<br></span>
Copier après la connexion
Abréviation :
<code><span style="font-size: 16px;">const answer = x > 10 ? 'is greater' : 'is lesser';</span>
const réponse = x > 'est plus grand' : 'est moindre';
Vous pouvez également imbriquer les instructions if : <span style="font-size: 16px;">const big = x > 10 ? " greater 10" : x</span>
2. Abréviation d'évaluation de court-circuit
Lorsque vous attribuez une autre valeur à une variable, vous voulez vous assurer que la valeur d'origine n'est pas valeur nulle ou indéfinie ou nulle. Vous pouvez écrire une instruction if multi-conditions.
1 |
|
Ou vous pouvez utiliser la méthode d'évaluation de court-circuit : <span style="font-size: 16px;">const variable2 = variable1 || 'new';</span>
<h2>const variable2 = variable1 || > code><span style="font-size: 16px;"></span>
</h2>3. Méthode abrégée de déclaration de variables<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false"><span style="font-size: 16px;">let x;<br>let y;<br>let z = 3;<br></span></pre><div class="contentsignin">Copier après la connexion</div></div>
<p><span style="font-size: 16px;"><br></span>Méthode abrégée : <code><span style="font-size: 16px;">let x, y, z=3;</span>
<h2> soit x, y, z = 3;<span style="font-size: 16px;"></span>
</h2>
4.if existe la méthode d'abréviation de condition<span style="font-size: 16px;">if (likeJavaScript === true)</span>
<span style="font-size: 16px;">if ( likeJavaScript === true)<br></span>
<span style="font-size: 16px;">if (likeJavaScript)</span>
if (likeJavaScript)
Seulement lorsque likeJavaScript est une vraie valeur, les deux déclarations sont égales
1 |
|
Si la valeur de jugement n'est pas une vraie valeur, vous pouvez faire ceci :
1 |
|
Abréviation :
<span style="font-size: 16px;">for (let i = 0; i < allImgs.length; i++)</span>
</span>pour (laissez i = 0; i < allImgs.length; i++)<code><span style="font-size: 16px;">for (let index in allImgs)</span>
Abréviation :
1 |
|
<h2 id="pour-laissez-l-index-dans-allImgs-span-style-font-size-px-code-span">pour (laissez l'index dans allImgs)<span style="font-size: 16px;">
Vous pouvez également utiliser Array.forEach : 1 |
|
La valeur attribuée à une variable En jugeant si sa valeur est nulle ou indéfinie, vous pouvez : <span style="font-size: 16px;">const dbHost = process.env.DB_HOST || 'localhost';</span>
Abréviation :
<span style="font-size: 16px;">const dbHost = process.env. DB_HOST || 'localhost';<br/>
<span style="font-size: 16px;">for (let i = 0; i < 10000; i++) {}</span>
Exposant décimal
1 |
|
</span>for (let i = 0; i < 10000 ; i++) {}</h2>
Abréviation :
<span style="font-size: 16px;">const obj = { x:x, y:y };</span>
8. Abréviation de l'attribut d'objet
<span style="font-size: 16px;">const obj = { x, y };</span>
Si le nom de l'attribut est le même que le nom de la clé, il peut être utilisé selon la méthode ES6 :
<span style="font-size: 16px;">const obj = { x:x, y:y };</span>
Abréviation :
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false"><span style="font-size: 16px;">function sayHello(name) {<br/> console.log(&#39;Hello&#39;, name);<br/>}<br/><br/>setTimeout(function() {<br/> console.log(&#39;Loaded&#39;)<br/>}, 2000);<br/><br/>list.forEach(function(item) {<br/> console.log(item);<br/>});<br/></span></pre><div class="contentsignin">Copier après la connexion</div></div>const obj = { x, y };<p>
9. Abréviation de la fonction flèche1
2
3
4
<span style=
"font-size: 16px;"
>sayHello = name => console.log(
'Hello'
, name);<br><br>setTimeout(() => console.log(
'Loaded'
), 2000);<br><br>list.forEach(item => console.log(item));<br></span><h2>
<span style=
"font-size: 16px;"
></span>La méthode traditionnelle d
'écriture de fonction est facile à comprendre et à écrire, mais lorsqu'
elle est imbriquée dans une autre fonction, ces avantages sont perdus. </h2>
<p><span style=
"font-size: 16px;"
></span></p> Abréviation : <p><span style=
"font-size: 16px;"
></span></p>
<pre
class
=
"brush:php;toolbar:false"
><span style=
"font-size: 16px;"
>
function
calcCircumference(diameter) {<br>
return
Math.PI * diameter<br>}<br><br>
var
func =
function
func() {<br>
return
{ foo: 1 };<br>};<br></span>
Copier après la connexion 10. Abréviation de la valeur de retour implicite
L'instruction return est souvent utilisée pour renvoyer le résultat final d'une fonction. Une fonction flèche avec une seule instruction peut implicitement renvoyer sa valeur (la fonction doit omettre {} afin d'omettre le mot-clé return) 1
<span style=
"font-size: 16px;"
>calcCircumference = diameter => (<br> Math.PI * diameter;<br>)<br><br>
var
func = () => ({ foo: 1 });<br></span>
Copier après la connexion
pour renvoyer plusieurs instructions Line (telles que des expressions littérales d'objet), vous devez utiliser () pour entourer le corps de la fonction.
Abréviation : 1
<span style=
"font-size: 16px;"
>
function
volume(l, w, h) {<br>
if
(w === undefined)<br> w = 3;<br>
if
(h === undefined)<br> h = 4;<br>
return
l * w * h;<br>}<br></span>
Copier après la connexion
11. Valeur du paramètre par défaut1
<span style=
"font-size: 16px;"
>volume = (l, w = 3, h = 4 ) => (l * w * h);<br><br>volume(2)
//output: 24<br></span>
Copier après la connexion
Pour Passer des valeurs par défaut aux paramètres dans les fonctions est généralement écrit à l'aide d'instructions if, mais utiliser ES6 pour définir les valeurs par défaut sera très concis :
Abréviation : 1
<span style=
"font-size: 16px;"
>
const
welcome =
'You have logged in as '
+ first +
' '
+ last +
'.'
<br><br>
const
db =
'http://'
+ host +
':'
+ port +
'/'
+ database;<br></span>
Copier après la connexion
12. Chaîne de modèle Dans le langage JavaScript traditionnel, le modèle de sortie est généralement écrit comme ceci. ES6 peut utiliser des backticks et l'abréviation ${} : 1
<span style=
"font-size: 16px;"
>
const
welcome = `You have logged in
as
${first} ${last}`;<br><br>
const
db = `http:
//${host}:${port}/${database}`;<br></span>
Copier après la connexion
13.解构赋值简写方法
在web框架中,经常需要从组件和API之间来回传递数组或对象字面形式的数据,然后需要解构它
1
<span style=
"font-size: 16px;"
>
const
observable =
require
(
'mobx/observable'
);<br>
const
action =
require
(
'mobx/action'
);<br>
const
runInAction =
require
(
'mobx/runInAction'
);<br><br>
const
store = this.props.store;<br>
const
form = this.props.form;<br>
const
loading = this.props.loading;<br>
const
errors = this.props.errors;<br>
const
entity = this.props.entity;<br></span>
Copier après la connexion
简写:
1
<span style=
"font-size: 16px;"
>import { observable, action, runInAction } from
'mobx'
;<br><br>
const
{ store, form, loading, errors, entity } = this.props;<br></span>
Copier après la connexion
也可以分配变量名:
1
<span style=
"font-size: 16px;"
>
const
{ store, form, loading, errors, entity:contact } = this.props;<br>
//最后一个变量名为contact<br></span>
Copier après la connexion
14.多行字符串简写
需要输出多行字符串,需要使用+来拼接:
1
<span style=
"font-size: 16px;"
>
const
lorem =
'Lorem ipsum dolor sit amet, consectetur\n\t'
<br> +
'adipisicing elit, sed do eiusmod tempor incididunt\n\t'
<br> +
'ut labore et dolore magna aliqua. Ut enim ad minim\n\t'
<br> +
'veniam, quis nostrud exercitation ullamco laboris\n\t'
<br> +
'nisi ut aliquip ex ea commodo consequat. Duis aute\n\t'
<br> +
'irure dolor in reprehenderit in voluptate velit esse.\n\t'
<br></span>
Copier après la connexion
使用反引号,则可以达到简写作用:
1
<span style=
"font-size: 16px;"
>
const
lorem = `Lorem ipsum dolor sit amet, consectetur<br> adipisicing elit, sed
do
eiusmod tempor incididunt<br> ut labore et dolore magna aliqua. Ut enim ad minim<br> veniam, quis nostrud exercitation ullamco laboris<br> nisi ut aliquip ex ea commodo consequat. Duis aute<br> irure dolor in reprehenderit in voluptate velit esse.`<br></span>
Copier après la connexion
15.扩展运算符简写
扩展运算符有几种用例让JavaScript代码更加有效使用,可以用来代替某个数组函数。
1
<span style=
"font-size: 16px;"
>
// joining arrays<br>const odd = [1, 3, 5];<br>const nums = [2 ,4 , 6].concat(odd);<br><br>// cloning arrays<br>const arr = [1, 2, 3, 4];<br>const arr2 = arr.slice()<br></span>
Copier après la connexion
简写:
1
<span style=
"font-size: 16px;"
>
// joining arrays<br>const odd = [1, 3, 5 ];<br>const nums = [2 ,4 , 6, ...odd];<br>console.log(nums); // [ 2, 4, 6, 1, 3, 5 ]<br><br>// cloning arrays<br>const arr = [1, 2, 3, 4];<br>const arr2 = [...arr];<br></span>
Copier après la connexion
不像concat()函数,可以使用扩展运算符来在一个数组中任意处插入另一个数组。
1
<span style=
"font-size: 16px;"
>
const
odd = [1, 3, 5 ];<br>
const
nums = [2, ...odd, 4 , 6];<br></span>
Copier après la connexion
也可以使用扩展运算符解构:
1
<span style=
"font-size: 16px;"
>
const
{ a, b, ...z } = { a: 1, b: 2, c: 3, d: 4 };<br>console.log(a)
// 1<br>console.log(b) // 2<br>console.log(z) // { c: 3, d: 4 }<br></span>
Copier après la connexion
16.强制参数简写
JavaScript中如果没有向函数参数传递值,则参数为undefined。为了增强参数赋值,可以使用if语句来抛出异常,或使用强制参数简写方法。
1
<span style=
"font-size: 16px;"
>
function
foo(bar) {<br>
if
(bar === undefined) {<br>
throw
new
Error(
'Missing parameter!'
);<br> }<br>
return
bar;<br>}<br></span>
Copier après la connexion
简写:
1
<span style=
"font-size: 16px;"
>mandatory = () => {<br>
throw
new
Error(
'Missing parameter!'
);<br>}<br><br>foo = (bar = mandatory()) => {<br>
return
bar;<br>}<br></span>
Copier après la connexion
17.Array.find简写
想从数组中查找某个值,则需要循环。在ES6中,find()函数能实现同样效果。
1
<span style=
"font-size: 16px;"
>
const
pets = [<br> { type:
'Dog'
, name:
'Max'
},<br> { type:
'Cat'
, name:
'Karl'
},<br> { type:
'Dog'
, name:
'Tommy'
},<br>]<br><br>
function
findDog(name) {<br>
for
(let i = 0; i<pets.length; ++i) {<br/>
if
(pets[i].type === 'Dog' && pets[i].name === name) {<br/>
return
pets[i];<br/> }<br/> }<br/>}<br/></span>
Copier après la connexion简写:
1
<span style=
"font-size: 16px;"
>pet = pets.find(pet => pet.type ===
'Dog'
&& pet.name ===
'Tommy'
);<br>console.log(pet);
// { type: 'Dog', name: 'Tommy' }<br></span>
Copier après la connexion
18.Object[key]简写
考虑一个验证函数
1
<span style=
"font-size: 16px;"
>
function
validate(values) {<br>
if
(!values.first)<br>
return
false;<br>
if
(!values.last)<br>
return
false;<br>
return
true;<br>}<br><br>console.log(validate({first:
'Bruce'
,last:
'Wayne'
}));
// true<br></span>
Copier après la connexion
假设当需要不同域和规则来验证,能否编写一个通用函数在运行时确认?
1
<span style=
"font-size: 16px;"
>
// 对象验证规则<br>const schema = {<br> first: {<br> required:true<br> },<br> last: {<br> required:true<br> }<br>}<br><br>// 通用验证函数<br>const validate = (schema, values) => {<br> for(field in schema) {<br> if(schema[field].required) {<br> if(!values[field]) {<br> return false;<br> }<br> }<br> }<br> return true;<br>}<br><br><br>console.log(validate(schema, {first:'Bruce'})); // false<br>console.log(validate(schema, {first:'Bruce',last:'Wayne'})); // true<br></span>
Copier après la connexion
现在可以有适用于各种情况的验证函数,不需要为了每个而编写自定义验证函数了
19.双重非位运算简写
有一个有效用例用于双重非运算操作符。可以用来代替Math.floor(),其优势在于运行更快,可以阅读此文章了解更多位运算。
<span style="font-size: 16px;">Math.floor(4.9) === 4 //true</span>
简写:
<span style="font-size: 16px;">~~4.9 === 4 //true</span>
相关推荐:
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!
<span style="font-size: 16px;">const obj = { x:x, y:y };</span>
<span style="font-size: 16px;">const obj = { x, y };</span>
Si le nom de l'attribut est le même que le nom de la clé, il peut être utilisé selon la méthode ES6 : <span style="font-size: 16px;">const obj = { x:x, y:y };</span>
1 2 3 4 |
|
1 |
|
1 |
|
1 |
|
1 |
|
1 |
|
1 |
|
1 |
|
1 |
|
1 |
|
1 |
|
1 |
|
1 |
|
1 |
|
1 |
|
1 |
|
1 |
|
1 |
|
1 |
|
1 |
|
1 |
|
<span style="font-size: 16px;">Math.floor(4.9) === 4 //true</span>
<span style="font-size: 16px;">~~4.9 === 4 //true</span>

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Quark Netdisk et Baidu Netdisk sont tous deux des outils de stockage très pratiques. De nombreux utilisateurs se demandent si ces deux logiciels sont interopérables ? Comment partager Quark Netdisk avec Baidu Netdisk ? Laissez ce site présenter en détail aux utilisateurs comment enregistrer les fichiers Quark Network Disk sur Baidu Network Disk. Comment enregistrer des fichiers de Quark Network Disk vers Baidu Network Disk Méthode 1. Si vous souhaitez savoir comment transférer des fichiers de Quark Network Disk vers Baidu Network Disk, téléchargez d'abord les fichiers qui doivent être enregistrés sur Quark Network Disk, puis ouvrez le client Baidu Network Disk, sélectionnez le dossier dans lequel le fichier compressé doit être enregistré et double-cliquez pour ouvrir le dossier. 2. Après avoir ouvert le dossier, cliquez sur « Télécharger » dans le coin supérieur gauche de la fenêtre. 3. Recherchez le fichier compressé qui doit être téléchargé sur votre ordinateur et cliquez pour le sélectionner.

1. Tout d'abord, nous entrons dans NetEase Cloud Music, puis cliquons sur l'interface de la page d'accueil du logiciel pour accéder à l'interface de lecture de chansons. 2. Ensuite, dans l'interface de lecture de la chanson, recherchez le bouton de fonction de partage en haut à droite, comme indiqué dans l'encadré rouge de la figure ci-dessous, cliquez pour sélectionner le canal de partage dans le canal de partage, cliquez sur l'option « Partager sur » sur en bas, puis sélectionnez le premier « WeChat Moments » qui vous permet de partager du contenu avec WeChat Moments.

La technologie de détection et de reconnaissance des visages est déjà une technologie relativement mature et largement utilisée. Actuellement, le langage d'application Internet le plus utilisé est JS. La mise en œuvre de la détection et de la reconnaissance faciale sur le front-end Web présente des avantages et des inconvénients par rapport à la reconnaissance faciale back-end. Les avantages incluent la réduction de l'interaction réseau et de la reconnaissance en temps réel, ce qui réduit considérablement le temps d'attente des utilisateurs et améliore l'expérience utilisateur. Les inconvénients sont les suivants : il est limité par la taille du modèle et la précision est également limitée ; Comment utiliser js pour implémenter la détection de visage sur le web ? Afin de mettre en œuvre la reconnaissance faciale sur le Web, vous devez être familier avec les langages et technologies de programmation associés, tels que JavaScript, HTML, CSS, WebRTC, etc. Dans le même temps, vous devez également maîtriser les technologies pertinentes de vision par ordinateur et d’intelligence artificielle. Il convient de noter qu'en raison de la conception du côté Web

Récemment, le client Android Baidu Netdisk a inauguré une nouvelle version 8.0.0. Cette version apporte non seulement de nombreux changements, mais ajoute également de nombreuses fonctions pratiques. Parmi eux, le plus frappant est l’amélioration de la fonction de partage de dossiers. Désormais, les utilisateurs peuvent facilement inviter des amis à rejoindre et partager des fichiers importants au travail et dans la vie, obtenant ainsi une collaboration et un partage plus pratiques. Alors, comment partager les fichiers que vous devez partager avec vos amis ? Ci-dessous, l'éditeur de ce site vous fera une introduction détaillée, j'espère qu'il pourra vous aider ! 1) Ouvrez l'application Baidu Cloud, cliquez d'abord pour sélectionner le dossier approprié sur la page d'accueil, puis cliquez sur l'icône [...] dans le coin supérieur droit de l'interface (comme indiqué ci-dessous) 2) Cliquez ensuite sur [+] dans la colonne "Membres partagés" 】, et enfin cochez tous

Mango TV propose différents types de films, séries télévisées, émissions de variétés et autres ressources, et les utilisateurs peuvent choisir librement de les regarder. Les membres de Mango TV peuvent non seulement regarder toutes les séries VIP, mais également définir la qualité d'image la plus haute définition pour aider les utilisateurs à regarder les séries avec plaisir. Ci-dessous, l'éditeur vous proposera des comptes d'adhésion gratuits à Mango TV que les utilisateurs pourront utiliser, dépêchez-vous et jetez un œil. Regarde. Mango TV dernier compte membre partage gratuit 2023 : Remarque : Ce sont les derniers comptes membres collectés, vous pouvez vous connecter et les utiliser directement, ne changez pas le mot de passe à volonté. Numéro de compte : 13842025699 Mot de passe : qds373 Numéro de compte : 15804882888 Mot de passe : evr6982 Numéro de compte : 13330925667 Mot de passe : jgqae Numéro de compte : 1703

Avec le développement rapide de la finance sur Internet, l'investissement en actions est devenu le choix de plus en plus de personnes. Dans le trading d'actions, les graphiques en bougies sont une méthode d'analyse technique couramment utilisée. Ils peuvent montrer l'évolution des cours des actions et aider les investisseurs à prendre des décisions plus précises. Cet article présentera les compétences de développement de PHP et JS, amènera les lecteurs à comprendre comment dessiner des graphiques en bougies boursières et fournira des exemples de code spécifiques. 1. Comprendre les graphiques en bougies boursières Avant de présenter comment dessiner des graphiques en bougies boursières, nous devons d'abord comprendre ce qu'est un graphique en bougies. Les graphiques en chandeliers ont été développés par les Japonais

Tutoriel JavaScript : Comment obtenir le code d'état HTTP, des exemples de code spécifiques sont requis Préface : Dans le développement Web, l'interaction des données avec le serveur est souvent impliquée. Lors de la communication avec le serveur, nous devons souvent obtenir le code d'état HTTP renvoyé pour déterminer si l'opération a réussi et effectuer le traitement correspondant en fonction de différents codes d'état. Cet article vous apprendra comment utiliser JavaScript pour obtenir des codes d'état HTTP et fournira quelques exemples de codes pratiques. Utilisation de XMLHttpRequest

Titre : Pour résoudre le problème de l'impossibilité d'afficher les partages Discuz WeChat, des exemples de code spécifiques sont nécessaires. Avec le développement de l'Internet mobile, WeChat est devenu un élément indispensable de la vie quotidienne des gens. Dans le développement de sites Web, afin d'améliorer l'expérience utilisateur et d'étendre la visibilité du site Web, de nombreux sites Web intégreront des fonctions de partage WeChat, permettant aux utilisateurs de partager facilement le contenu du site Web avec des groupes Moments ou WeChat. Cependant, parfois, lorsque vous utilisez des systèmes de forum open source tels que Discuz, vous rencontrerez le problème de l'impossibilité d'afficher les partages WeChat, ce qui entraîne certaines difficultés pour l'expérience utilisateur.
