@charset "UTF-8";
.markdown-body { line-height: 1.75; font-weight: 400; font-size: 15px; overflow-x: hidden; color: rgba(43, 43, 43, 1); font-family: -apple-system, system-ui, BlinkMacSystemFont, Helvetica Neue, PingFang SC, Hiragino Sans GB, Microsoft YaHei, Arial, sans-serif; background-image: linear-gradient(90deg, rgba(159, 219, 252, 0.15) 3%, rgba(0, 0, 0, 0) 0), linear-gradient(1turn, rgba(159, 219, 252, 0.15) 3%, rgba(0, 0, 0, 0) 0); background-size: 20px 20px; background-position: center }
.markdown-body h1, .markdown-body h2, .markdown-body h3, .markdown-body h4, .markdown-body h5, .markdown-body h6 { padding: 30px 0; margin-top: 35px; margin-bottom: 10px; color: rgba(77, 208, 225, 1) }
.markdown-body h1 { font-size: 30px; text-align: center; position: relative; width: max-content; margin: 0 auto }
.markdown-body h1:before { position: absolute; content: ""; z-index: -1; top: -20px; height: 100%; width: 100px; left: 0; right: 0; margin: 0 auto; background: url("") center / 64px 64px no-repeat; opacity: 0.84 }
.markdown-body h1:after { position: absolute; content: ""; width: 150%; left: -25%; height: 50%; bottom: 12px; border-radius: 50%; background: linear-gradient(rgba(0, 0, 0, 0) 80%, rgba(77, 208, 225, 0.8)); opacity: 0.6; animation: 6s linear infinite h1animate }
@keyframes h1Animate { 0% { background-position: right bottom } 50% { background-position: right } 100% { background-position: right bottom } }
.markdown-body h2 { display: block; border-bottom: 4px solid rgba(77, 208, 225, 1); position: relative; font-size: 24px; padding: 12px 32px; margin: 30px 0 }
.markdown-body h2:before { width: 24px; height: 24px; left: 0; top: 0; margin: auto; background-size: 24px 24px; background-image: url("") }
.markdown-body h2:after, .markdown-body h2:before { content: ""; display: block; position: absolute; bottom: 0 }
.markdown-body h2:after { right: 0; width: 400px; height: 10px; border-top-right-radius: 24px; background: linear-gradient(90deg, rgba(255, 255, 255, 1), rgba(77, 208, 225, 1)); max-width: 50vw }
.markdown-body h3 { margin: 30px 0; font-size: 18px; position: relative; padding: 4px 32px; width: max-content }
.markdown-body h3:before { border-bottom: 2px solid rgba(77, 208, 225, 1); width: 100%; content: ""; display: block; height: 28px; position: absolute; left: 0; top: 0; bottom: -2px; margin: auto; background-size: 28px 28px; background-image: url(""); background-repeat: no-repeat; animation: 2s infinite alternate h3animationbefore }
@keyframes h3AnimationBefore { 0% { width: 28px } 25% { width: 100% } 50% { width: 100% } 100% { width: 100% } }
.markdown-body h3:after { content: ""; display: block; width: 28px; height: 28px; position: absolute; border: 2px solid rgba(77, 208, 225, 1); border-radius: 50%; right: -15px; top: 0; bottom: 0; margin: auto; background-size: 28px 28px; background-image: url(""); animation: 2s infinite alternate h3animationafter }
@keyframes h3AnimationAfter { 0% { } 10% { } 50% { transform: rotate(-1turn) } 100% { transform: rotate(-1turn) } }
.markdown-body h4 { font-size: 16px }
.markdown-body h5 { font-size: 15px }
.markdown-body h6 { margin-top: 5px }
.markdown-body p { line-height: inherit; margin: 22px 0; letter-spacing: 2px; font-size: 14px; word-spacing: 2px }
.markdown-body img { max-width: 80%; border-radius: 6px; display: block; margin: 20px auto !important; object-fit: contain; box-shadow: 0 0 16px rgba(110, 110, 110, 0.45) }
.markdown-body figcaption { display: block; font-size: 13px; color: rgba(43, 43, 43, 1) }
.markdown-body figcaption:before { content: ""; background-image: url(""); display: inline-block; width: 18px; height: 18px; background-size: 18px; background-repeat: no-repeat; background-position: center; margin-right: 5px; margin-bottom: -5px }
.markdown-body hr { border-top: 1px solid rgba(77, 208, 225, 1); border-right: none; border-bottom: none; border-left: none; margin-top: 32px; margin-bottom: 32px }
.markdown-body del { color: rgba(77, 208, 225, 1) }
.markdown-body code { border-radius: 2px; overflow-x: auto; background-color: rgba(77, 208, 225, 0.08); color: rgba(38, 198, 218, 1); padding: 0.195em 0.4em }
.markdown-body pre { font-family: Menlo, Monaco, Consolas, Courier New, monospace; overflow: auto; position: relative; line-height: 1.75; box-shadow: 0 0 8px rgba(110, 110, 110, 0.45); border-radius: 4px; margin: 16px }
.markdown-body pre:before { content: ""; display: block; height: 30px; width: 100%; margin-bottom: -7px; background: url("") 10px 10px / 40px no-repeat }
.markdown-body pre>code { font-size: 12px; padding: 15px 12px; margin: 0; word-break: normal; display: block; overflow-x: auto; color: rgba(51, 51, 51, 1); background: rgba(248, 248, 248, 1) }
.markdown-body a { color: rgba(77, 208, 225, 1); border-bottom: 1px solid rgba(77, 208, 225, 1); font-weight: 400; text-decoration: none; margin: 0 4px }
.markdown-body a:active, .markdown-body a:hover { background-color: rgba(77, 208, 225, 0.1) }
.markdown-body strong { color: rgba(38, 198, 218, 1) }
.markdown-body strong:before { content: "「" }
.markdown-body strong:after { content: "」" }
.markdown-body em { font-style: normal; color: rgba(77, 208, 225, 1); font-weight: 700 }
.markdown-body table { display: inline-block !important; font-size: 12px; width: auto; max-width: 100%; overflow: auto; border: 1px solid rgba(246, 246, 246, 1) }
.markdown-body thead { background: rgba(246, 246, 246, 1); color: rgba(0, 0, 0, 1); text-align: left }
.markdown-body tr:nth-child(2n) { background-color: rgba(77, 208, 225, 0.05) }
.markdown-body td, .markdown-body th { padding: 12px 7px; line-height: 24px }
.markdown-body td { min-width: 120px }
.markdown-body blockquote { margin: 2em 0; padding: 24px 32px; border-left: 4px solid rgba(38, 198, 218, 1); background: rgba(77, 208, 225, 0.15); position: relative }
.markdown-body blockquote:before { content: "❝"; top: 8px; left: 8px; color: rgba(77, 208, 225, 1); font-size: 30px; line-height: 1; font-weight: 700; position: absolute; opacity: 0.7 }
.markdown-body blockquote:after { content: "❞"; font-size: 30px; position: absolute; right: 8px; bottom: 0; color: rgba(77, 208, 225, 1); opacity: 0.7 }
.markdown-body blockquote p { color: rgba(89, 89, 89, 1); line-height: 2 }
.markdown-body ol, .markdown-body ul { color: rgba(89, 89, 89, 1); padding-left: 28px }
.markdown-body ol li, .markdown-body ul li { margin-bottom: 0; list-style: inherit }
.markdown-body ol li .task-list-item, .markdown-body ul li .task-list-item { list-style: none }
.markdown-body ol li .task-list-item ol, .markdown-body ol li .task-list-item ul, .markdown-body ul li .task-list-item ol, .markdown-body ul li .task-list-item ul { margin-top: 0 }
.markdown-body ol ol, .markdown-body ol ul, .markdown-body ul ol, .markdown-body ul ul { margin-top: 3px }
.markdown-body ol li { padding-left: 6px }
@media (max-width: 720px) { .markdown-body h1 { font-size: 24px } .markdown-body h2 { font-size: 20px } .markdown-body h3 { font-size: 18px } }.markdown-body pre, .markdown-body pre>code.hljs { background: rgba(255, 255, 255, 1) }
.hljs-subst, .markdown-body pre, .markdown-body pre>code.hljs { color: rgba(67, 79, 84, 1) }
.hljs-attribute, .hljs-doctag, .hljs-keyword, .hljs-name, .hljs-selector-tag { color: rgba(0, 151, 157, 1) }
.hljs-addition, .hljs-built_in, .hljs-bullet, .hljs-code, .hljs-literal { color: rgba(211, 84, 0, 1) }
.hljs-link, .hljs-regexp, .hljs-selector-attr, .hljs-selector-pseudo, .hljs-symbol, .hljs-template-variable, .hljs-variable { color: rgba(0, 151, 157, 1) }
.hljs-deletion, .hljs-quote, .hljs-selector-class, .hljs-selector-id, .hljs-string, .hljs-template-tag, .hljs-type { color: rgba(0, 92, 95, 1) }
.hljs-section, .hljs-title { color: rgba(136, 0, 0, 1); font-weight: 700 }
.hljs-comment { color: rgba(149, 165, 166, 0.8) }
.hljs-meta-keyword { color: rgba(114, 142, 0, 1) }
.hljs-meta { color: rgba(67, 79, 84, 1) }
.hljs-emphasis { font-style: italic }
.hljs-strong { font-weight: 700 }
.hljs-function { color: rgba(114, 142, 0, 1) }
.hljs-number { color: rgba(138, 123, 82, 1) }

JavaScript的开发过程中,可以采用一些最佳实践来提高代码质量、性能和可维护性。这篇文章将介绍一些JavaScript的最佳实践,从基础到高级。

1. 基础实践

使用严格模式

在编写JavaScript代码时,建议启用严格模式。严格模式是一种特殊的JavaScript运行模式,它可以帮助我们在编写代码时捕捉一些隐藏的错误,例如变量名未定义、变量名重复、禁止使用一些unsafe的功能等。使用严格模式也可以提高JavaScript代码的运行速度,避免一些意外的行为。

在函数或模块的开头加上"use strict",就可以开启严格模式,例如:

function foo() {
'use strict';
// 这里是严格模式
}

避免全局变量

JavaScript中,全局变量是指在任何地方都可以访问的变量,如果不加限制地使用全局变量,会有多个文件同时使用同名变量的问题,容易导致命名冲突和代码混乱。

为了避免全局变量,我们可以使用工厂函数、单例模式或命名空间等方式,将变量限制在指定的作用域内。例如:

// 使用工厂函数创建变量
function createCounter() {
let count = 0;
return function() {
return ++count;
}
}
let counter = createCounter();
console.log(counter()); // 1
console.log(counter()); // 2 // 使用单例模式创建变量
let Config = (function() {
let instance;
function createInstance() {
let object = new Object({ foo: 'bar' });
return object;
}
return {
getInstance: function() {
if (!instance) {
instance = createInstance();
}
return instance;
}
};
})();
console.log(Config.getInstance().foo); // bar // 使用命名空间创建变量
let myApp = myApp || {};
myApp.namespace = function(ns_string) {
let parts = ns_string.split('.'),
parent = myApp,
i;
if (parts[0] === "myApp") {
parts = parts.slice(1);
}
for (i = 0; i < parts.length; i += 1) {
if (typeof parent[parts[i]] === "undefined") {
parent[parts[i]] = {};
}
parent = parent[parts[i]];
}
return parent;
};
myApp.namespace("myApp.modules.module1");
myApp.modules.module1.data = { foo: 'bar' };
console.log(myApp.modules.module1.data.foo); // bar

理解变量提升和作用域

JavaScript中,因为变量提升和作用域的原因,程序中定义的变量会在程序最顶端自动提升。因此,注重代码表现和安全性,建议使用let关键字来申明变量,而不是var关键字。

console.log(a); // undefined
var a = 1;
console.log(a); // 1 console.log(b); // ReferenceError: b is not defined
let b = 2;
console.log(b); // 2

在了解了变量提升后,我们还需要了解变量的作用域问题。在JavaScript中,有全局作用域和函数作用域两种,全局作用域中的变量可以在程序的任何地方访问,在函数内部申明的变量只能在函数体内访问。

let a = 1; // 全局变量

function foo() {
let b = 2; // 函数作用域变量console.log(a); // 1
console.log(b); // 2
}
foo(); console.log(a); // 1
console.log(b); // ReferenceError: b is not defined

2. 代码组织

使用IIFE

在JavaScript中,我们可以使用自执行函数(Immediately-invoked Function Expression)IIFE将代码放入一个函数中,来创建一个私有作用域,防止变量污染全局作用域和其他代码模块。例如:

(function() {
// 这里是私有作用域
})();

将代码分为模块

在JavaScript的开发中,我们可以将代码分为模块,对于每个模块,只暴露必要的接口,避免暴露不必要的实现细节。例如:

// module1.js
const module1 = (function() {
const privateVar = 'foo';
function privateFunc() {
console.log('Hello, World!');
}
return {
publicFunc: function() {
privateFunc();
},
publicVar: privateVar
};
})();
// 对外暴露模块的公共接口
export default module1; // app.js
import module1 from './module1.js';
module1.publicFunc(); // Hello, World!
console.log(module1.publicVar); // foo

使用ES6模块

在ES6中,我们可以使用export和import关键字来定义和导入模块,这样可以更方便地管理依赖关系,避免代码污染和命名冲突。例如:

// module1.js
const privateVar = 'foo';
function privateFunc() {
console.log('Hello, World!');
}
export function publicFunc() {
privateFunc();
}
export const publicVar = privateVar; // app.js
import { publicFunc, publicVar } from './module1.js';
publicFunc(); // Hello, World!
console.log(publicVar); // foo

3. 函数

使用纯函数

在JavaScript中,我们应该尽可能使用纯函数。纯函数是指不产生副作用的函数,即在函数内部不修改全局变量或其他作用域的变量,只返回一个新值。

使用纯函数可以带来一些好处,例如代码更加容易测试、更容易复用、更容易并行化等。例如:

// impure function
let x = 10;
function impure() {
x++;
}
console.log(x); // 10
impure();
console.log(x); // 11 // pure function
function pure(y) {
return y + 1;
}
let z = pure(x);
console.log(x); // 11
console.log(z); // 12

避免副作用

JavaScript中的副作用是指函数在执行期间对外部作用域产生的影响,例如修改全局变量、发送网络请求、读取文件等。为了使代码更加可维护和容易推理,我们应该尽可能避免副作用的情况。

在代码编写的过程中,保持良好的命名规范、使用const和let来定义变量、封装函数等都有助于避免副作用。例如:

// 副作用函数
let x = 10;
function sideEffect() {
x = x + 1;
}
console.log(x); // 10
sideEffect();
console.log(x); // 11 // 避免副作用函数
const add = (a, b) => a + b;
console.log(add(1, 2)); // 3

尽管有些时候我们无法完全避免副作用,但我们可以将它们限制在一个特定的作用域中,并且提供明确的文档来描述副作用的影响。

使用默认参数和解构赋值

在ES6中,我们可以使用默认参数和解构赋值来使函数更加简洁和易于阅读。默认参数是指在函数中可以设置参数的默认值,如果参数没有被提供,则使用默认值。例如:

function greet(name = 'World') {
console.log(`Hello, ${name}!`);
}
greet(); // Hello, World!
greet('John'); // Hello, John!

解构赋值是指在函数参数中,可以使用对象或数组的解构语法,来提取对象或数组中的属性或元素,使代码更加简洁。例如:

// 对象解构
function printEmployeeName({ name }) {
console.log(`Employee name is ${name}`);
}
let employee = { id: 1, name: 'John Doe', age: 30 };
printEmployeeName(employee); // Employee name is John Doe // 数组解构
function printArrayElements([first, second, ...rest]) {
console.log(first, second, rest);
}
printArrayElements([1, 2, 3, 4, 5]); // 1 2 [3, 4, 5]

4. 异步编程

Promise的使用

在JavaScript的异步编程中,Promise是一种常用的解决方案,可以避免异步回调函数所带来的代码可读性和复杂度问题。

Promise是一种对象,可以用来处理异步操作,它有三种状态:未完成(pending)、已完成(fulfilled)、已拒绝(rejected)。可以使用Promise来封装异步操作,并在异步操作完成时,根据操作结果来决定Promise的状态。例如:

function fetchData() {
return new Promise((resolve, reject) => {
setTimeout(() => {
resolve('Data has been fetched');
}, 2000);
});
} fetchData()
.then((result) => {
console.log(result);
})
.catch((error) => {
console.error(error);
});

async/await

async/await是ES7中新增的异步编程语法糖,它可以让异步代码看起来更像同步代码,提高了代码的可读性。async关键字和await关键字配合使用,可以将异步操作变为同步式的调用,例如:

function fetchData() {
return new Promise((resolve, reject) => {
setTimeout(() => {
resolve('Data has been fetched');
}, 2000);
});
} async function printData() {
let data = await fetchData();
console.log(data);
} printData();

避免回调地狱

JavaScript中的回调地狱是指,多层嵌套异步回调函数所造成的代码可读性和维护性降低的问题。为了避免回调地狱,我们可以使用Promise、async/await等方式,或者使用第三方库来提供支持,例如:

  • Async.js
  • Bluebird
  • Q

5. 性能优化

避免DOM操作

在JavaScript中,DOM操作是一种比较费时的操作,会导致页面渲染的效率下降。为了提高性能,我们应该尽量避免DOM操作,可以将操作数据存储在JavaScript中,而不是在DOM中。

例如,可以使用documentFragment代替直接操作DOM,一次性向DOM中插入一组节点;或者使用虚拟DOM等技术来减少DOM操作的次数。例如:

const data = ['Apple', 'Banana', 'Orange'];
const ul = document.createElement('ul'); for (let i = 0; i < data.length; i++) {
const li = document.createElement('li');
li.innerText = data[i];
ul.appendChild(li);
} // 直接每次循环插入DOM
document.body.appendChild(ul); // 使用documentFragment一次性插入DOM
const fragment = document.createDocumentFragment();
for (let i = 0; i < data.length; i++) {
const li = document.createElement('li');
li.innerText = data[i];
fragment.appendChild(li);
}
ul.appendChild(fragment);
document.body.appendChild(ul);

使用事件委托

在JavaScript中,事件委托是一种优化性能的常用方式,它可以将事件处理程序绑定到它们的共同父元素上,而不是绑定到每个子元素上。这样可以减少事件处理程序的数量,避免内存泄漏,提高页面的响应速度。

例如,可以在tbody元素上绑定click事件,使用event.target属性来判断用户点击的具体元素,然后做相应的处理。例如:

const tbody = document.querySelector('tbody');
tbody.addEventListener('click', function(event) {
const target = event.target;
if (target.matches('td.deleteButton')) {
const row = target.closest('tr');
row.remove();
}
});

减少网络请求

在Web应用程序中,网络请求是一个比较耗费时间的操作,可以通过减少网络请求的次数来提高网站的访问速度。可以使用一些技术来实现减少网络请求,例如:

  • 图片压缩:使用工具对图片进行压缩,减少图片的大小,加快图片加载速度。
  • 合并脚本和样式表:将多个脚本和样式表合并为一个脚本和一张样式表,可以减少HTTP请求的次数,提高页面性能。
  • 使用CDN:使用CDN(Content Delivery Network)可以将静态资源(例如CSS、JS、图片)存储在CDN服务器上,加快页面的加载速度。

6. 错误处理

检测和处理异常

在JavaScript中,代码中可能会出现异常,例如语法错误、运行时错误、网络错误等,为了避免这些异常终止代码的执行,我们需要检测和处理这些异常。

可以使用try...catch语句来捕获异常,给出错误提示和相应的处理方法。例如:

try {
// 可能出现异常的代码
const foo = bar;
} catch (error) {
// 异常处理代码
console.error(error);
alert('An error occurred: ' + error.message);
}

自定义错误类型

在JavaScript中,我们可以自定义自己的错误类型,以便于更好地处理不同类型的错误信息。这可以通过创建自定义错误类并继承内置错误类来实现。

下面是一个自定义错误类型的代码示例:

class CustomError extends Error {
constructor(message) {
super(message);
this.name = "CustomError";
}
}

我们可以使用throw关键字抛出自定义错误:

throw new CustomError("This is a custom error message");

使用try-catch

由于JavaScript是一门解释性语言,因此很难提前发现错误,因此try-catch语句成为了一种处理可能发生错误的情况的最佳方式。

下面是一个try-catch语句的代码示例:

try {
// 可能会抛出错误的代码
} catch (error) {
// 错误信息处理
}

在以上代码示例中,我们可以把有可能会出错的代码块放在try语句中,如果有错误则会被catch语句捕获。我们可以在catch语句中处理错误信息。

7.安全性

避免跨站脚本攻击

跨站脚本攻击(XSS)是指攻击者通过在Web页面中注入恶意脚本来攻击用户的一种方式。为了避免跨站脚本攻击,我们需要对用户输入进行过滤和验证。

下面是一个基本的示例来防止跨站脚本攻击:

const input = document.getElementById("userInput").value; // 获取用户输入
const cleanInput = encodeURI(input); // 对用户输入进行编码
document.getElementById("output").innerHTML = cleanInput; // 输出编码过的文本

在以上代码示例中,我们使用encodeURI函数对用户输入进行编码来防止跨站脚本攻击。

验证用户输入

除了防止跨站脚本攻击,还要对用户输入进行验证,以确保它们符合预期。例如,我们可以使用正则表达式来验证电子邮件地址是否正确,并使用preventDefault函数防止表单被提交。

以下是一个基本的示例来验证电子邮件地址:

const email = document.getElementById("email").value; // 获取电子邮件地址
const pattern = /^[^\s@]+@[^\s@]+\.[^\s@]+$/; // 定义电子邮件地址的正则表达式
if (pattern.test(email)) { // 如果符合预期,则防止表单提交
event.preventDefault(); // 防止表单提交
alert("Email address is valid"); // 显示有效信息
} else {
alert("Invalid email address"); // 邮件地址无效
}

将敏感数据加密存储

代码中的敏感数据应该在存储时加密以保护其安全性。以下是一个基本的示例来使用AES算法加密和解密敏感数据:

const secret = "This is a secret message"; // 待加密的私密消息
const password = "myPassword"; // 密码
const encryptedData = CryptoJS.AES.encrypt(secret, password).toString(); // 使用AES算法加密数据
const decryptedData = CryptoJS.AES.decrypt(encryptedData, password).toString(CryptoJS.enc.Utf8); // 使用AES算法解密数据

请注意,以上示例假定正在使用CryptoJS库来实现加密和解密。如果使用其他的库,请参考相关文档以进行操作。

总结

本文介绍了几个JavaScript最佳实践,通过实现这些最佳实践,可以提高JavaScript代码的安全性和可靠性。

同时,这些最佳实践也有助于提高代码的可维护性和可读性。例如,自定义错误类型可以使代码在处理错误时变得更加清晰和可读。使用try-catch可以帮助开发人员更好地处理可能发生的错误情况。安全性实践则可以保护敏感数据和防止恶意攻击等等。

总之,JavaScript最佳实践可以大大提高代码质量和安全性,以及开发Web应用程序的信心。开发人员应该考虑这些实践并在开发过程中积极应用它们,以编写更好、更安全和更可维护的JavaScript代码

在开发JavaScript应用程序时,遵循最佳实践是非常重要的,这有助于保持代码质量和开发生产级应用程序的信心。希望这些最佳实践对您有所帮助,使您能够开发出更好、更安全、更可靠的JavaScript应用程序。

JavaScript最佳实践:从基础到高级的更多相关文章

  1. JavaScript 最佳实践

    这个文档是基于JavaScript社区众多开发者的意见和经验,在开发JavaScript代码上的最佳实践和首选的方案的明细表.因为这是一个推荐的表而非原则性的方案,经验丰富的开发者可能对下面的表达会有 ...

  2. java-mybaits-015-mybatis逆向工程最佳实践【基础mybatis-generator、tk.mybatis、mubatis-plus】

    一.概述 三款框架的功能对比 Mybatis-generator 通用Mapper Mybatis-Plus 代码生成器 支持自动生成Model,Mapper,Mapper XML文件 生成方式不够灵 ...

  3. 【原】javascript最佳实践

    摘要:这篇文章主要内容的来源是<javascript高级程序设计第三版>,因为第二遍读完,按照书里面的规范,发觉自己在工作中没有好好遵守.所以此文也是对自己书写js的一种矫正. 1.可维护 ...

  4. JavaScript最佳实践:可维护性

    代码约定 一.可读性 代码缩进 包含注释 二.变量和函数命名 变量名应为名词如car或person 函数名应该以动词开始,如getName().返回布尔类型值的函数一般以is开头,如isEnable( ...

  5. 学习JavaScript最佳实践方法

    首先要说明的是,咱现在不是高手,最多还是一个半桶水,算是入了JS的门. 谈不上经验,都是一些教训. 这个时候有人要说,“靠,你丫半桶水,凭啥教我们”.您先别急着骂,先听我说. 你叫一个大学生去教小学数 ...

  6. javascript 最佳实践 ( 24 章 )

    代码约定 易于维护, 形成了一套 JavaScript 代码书写的约定: 跟别的语言差不多, 不过 javascript 中的大括号一定要放在 行尾, 例如: function abc() { // ...

  7. 15条JavaScript最佳实践【转】

    本文档整理大部分公认的.或者少有争议的JavaScript良好书写规范(Best Practice).一些显而易见的常识就不再论述(比如要用对象支持识别判断,而不是浏览器识别判断:比如不要嵌套太深). ...

  8. JavaScript最佳实践

    作者:Grey 原文地址: http://www.cnblogs.com/greyzeng/p/5540469.html 举个例子:用户在点击某个链接的时候弹出一个新窗口 弹出窗口的方法采用:wind ...

  9. 15条JavaScript最佳实践很经典噢

    感觉比较经典,特转载腾讯大讲堂.本文档整理大部分公认的.或者少有争议的JavaScript良好书写规范(Best Practice).一些显而易见的常识就不再论述(比如要用对象支持识别判断,而不是浏览 ...

  10. ASP.NET Core Web API 最佳实践指南

    原文地址: ASP.NET-Core-Web-API-Best-Practices-Guide 介绍 当我们编写一个项目的时候,我们的主要目标是使它能如期运行,并尽可能地满足所有用户需求. 但是,你难 ...

随机推荐

  1. ABB喷涂机器人维护保养

    正确规范的ABB喷涂机器人保养能够最大限度保证机器人正常运行, 保证经济效率并提高产量.因此,预防性喷涂机器人保养是一项不可或缺的工作. ABB喷涂机器人正常运行每3年或10000小时后,则需要做一次 ...

  2. QT5笔记: 29. 文本文件读写

    例子:主要讲了 QFile .QTextStream 进行文本文件读写 MainWindow.h #ifndef MAINWINDOW_H #define MAINWINDOW_H #include ...

  3. 互联网和DeepSeak时代,获取信息这么容易,为什么我们还是学习不好?

    因为人性倾向于立即获得享受,而不是延迟获得享受,然而,学习就是延迟获得享受,所以,学习,其实是反人性的一种活动. 学习,特别是对知识的深入学习,其实需要付出大量的时间和精力,这个过程中必然伴随着各种各 ...

  4. 八米云-Hyper-V虚拟机安装教程

    疑难解答加微信机器人,给它发:进群,会拉你进入八米交流群 机器人微信号:bamibot 简洁版教程访问:https://bbs.8miyun.cn 准备阶段: 八米云启动U盘(制作方法可参看<制 ...

  5. Flink - [04] 窗口(Windows)

    题记部分 一.Flink中的窗口是什么 (1)一般真实的流都是无界的,怎样处理无界的数据? (2)可以把无限的数据流进行切分,得到有限的数据集进行处理 -- 也就是得到有界流 (3)窗口(Window ...

  6. Linux - centos6.6升级openssh9.7p1

    一.注意事项 1.任何会被修改的配置文件都要提前备份 2.每一步操作都要记录 3.提前预演,知道可能遇到的问题,以及对应的解决方法,能够在生产环境上升级时,更快完成操作. 4.一开始用来操作的ssh会 ...

  7. Open-Sora 2.0 重磅开源!

    潞晨科技正式推出 Open-Sora 2.0 -- 一款全新开源的 SOTA 视频生成模型,仅 20 万美元(224 张 GPU)成功训练商业级 11B 参数视频生成大模型.开发高性能的视频生成模型通 ...

  8. docker网络冲突解决(修改docker_gwbridge网段)

    1·问题 一次生产搭建服务的时候,出现客户端服务器到docker服务断开不通的情况,在docker服务器上抓包可以抓到客户端服务器的包,但是docker服务器不做任何响应 于是ip route 查看本 ...

  9. Noise——随机之美

    本篇博文介绍图形学中噪音生成的一般方法. Noise可以干什么? 不规则表面生成 有机体模拟 流体烟雾模拟 甚至是使用noise对灯光强度,位置做扰动: 只有我们想象不到的,没有noise不能涉猎的! ...

  10. Arrays.asList() 详解

    [1. 要点] 该方法是将数组转化成List集合的方法. List list = Arrays.asList("a","b","c"); 注 ...