Web 前端最佳实践
前端
选择器
- 尽量使用ID选择器
- 基于Id的选择器:先使用ID选择器定位,然后再使用find方法精确查找
// Fast:$( "#container div.robotarm" );// Super-fast:$( "#container" ).find( "div.robotarm" );
- 指定选择的上下文
// 劣质的代码:因为需要遍历整个DOM来找到.class$('.class');// 高品代码:因为只需在指定容器范围内进行查找$('.class', '#class-container');
这一条是否有上一条等同?
- 多级查找:右边尽量指定得详细点而左边则尽量简单点
// Unoptimized:$( "div.data .gonzalez" );// Optimized:$( ".data td.gonzalez" );
- 避免冗余
$( ".data table.attendees td.gonzalez" );// Better: Drop the middle if possible.$( ".data td.gonzalez" );
- 不要ID与其它选择器混搭
ID已经表示唯一了,再加上其它选择符只会加重选择器的负担
$('#outer #inner'); // 脏$('div#inner'); // 乱$('.outer-container #inner'); // 差$('#inner'); // 干净利落,后台只需调用document.getElementById()
- 不要使用万能选择器
$( ".buttons > *" ); // Extremely expensive.$( ".buttons" ).children(); // Much better.$( ".category :radio" ); // Implied universal selection.$( ".category *:radio" ); // Same thing, explicit now.$( ".category input:radio" ); // Much better.
Dom 操作
避免DOM节点频繁流化
样本代码
$.each( myArray, function( i, item ) {var newListItem = "<li>" + item + "</li>";$( "#ballers" ).append( newListItem );});
方法一: 临时detach
var ballers = $("#ballers");var parent = ballers.parent();ballers.detach();$.each(myArray, function(i, item) {var newListItem = "<li>" + item + "</li>";ballers.append(newListItem);});parent.append(ballers);var table = $( "#myTable" );var parent = table.parent();table.detach();// ... add lots and lots of rows to tableparent.append( table );
方法二:创建临时DOM节点
var frag = document.createDocumentFragment();$.each( myArray, function( i, item ) {var newListItem = document.createElement( "li" );var itemText = document.createTextNode( item );newListItem.appendChild( itemText );frag.appendChild( newListItem );});$( "#ballers" )[ 0 ].appendChild( frag );
方法三:append html
var myHtml = "";$.each( myArray, function( i, item ) {myHtml += "<li>" + item + "</li>";});$( "#ballers" ).html( myHtml );
临时改变多个节点样式
// Fine for up to 20 elements, slow after that:$( "a.swedberg" ).css( "color", "#0769ad" );// Much faster:$( "<style type=\"text/css\">a.swedberg { color: #0769ad }</style>").appendTo( "head" );//预定义css类会更好// .swedberg_color{color:#0769ad}$( "a.swedberg" ).addClass("swedberg_color" );
CSS
JS 编码
代码组织
链式写法要换行
$("#myLink").addClass("bold").on("click", myClickHandler).on("mouseover", myMouseOverHandler).show();
链式写法中避免使用匿名函数,否则会严重影响代码易读性
使用变量保存选择器结果方便重用
//bad$("#myLink").addClass("bold");//stuff$("#myLink").on("click", myClickHandler)//bettervar myLink=$("#myLink").addClass("bold");//stuffmyLink.on("click", myClickHandler)
利用闭包保持代码整洁
//badvar privateThing = "secret";var publicThing = "not secret";var changePrivateThing = function() {privateThing = "super secret";};var sayPrivateThing = function() {console.log( privateThing );changePrivateThing();};sayPrivateThing();//bettervar feature = (function() {// Private variables and functionsvar privateThing = "secret";var publicThing = "not secret";var changePrivateThing = function() {privateThing = "super secret";};var sayPrivateThing = function() {console.log( privateThing );changePrivateThing();};// Public APIreturn {publicThing: publicThing,sayPrivateThing: sayPrivateThing};})();feature.sayPrivateThing();
- 利用“事件冒泡”机制进行事件绑定
//bad$('ul>li').on('click',clientHandler);//better$('ul').on('click','li',clientHandler);
- 数组循环中不要每次循环都访问数组的长度,应该先缓存长度
//好的写法var myLength = myArray.length;for ( var i = 0; i < myLength; i++ ) {// do stuff}//好的写法for ( var i = 0,myLength=myArray.length; i < myLength; i++ ) {// do stuff}//差的写法for ( var i = 0; i < myArray.length; i++ ) {// do stuff}
- 其它
//bad// 糟糕:调用了三次attr$myLink.attr("href", "#").attr("title", "my link").attr("rel", "external");//better// 不错,只调用了一次attr,css函数与此类似$myLink.attr({href: "#",title: "my link",rel: "external"});
参考
Web 前端最佳实践的更多相关文章
- ASP.NET Core Web API 最佳实践指南
原文地址: ASP.NET-Core-Web-API-Best-Practices-Guide 介绍 当我们编写一个项目的时候,我们的主要目标是使它能如期运行,并尽可能地满足所有用户需求. 但是,你难 ...
- JavaScript Web 应用最佳实践分析
[编者按]本文作者为 Mathias Schäfer,旨在回顾在客户端大量使用JavaScript 的最佳 Web应用实践.文章系国内 ITOM 管理平台 OneAPM 编译呈现. 对笔者来说,Jav ...
- 8102 年的现代 Web 开发最佳实践(笑)
简评:8102 年了,现在 web 开发的最佳实践是什么,让本文来告诉你.原文只提到一部分,可以查看 reddit 上对此文的评论查看补充的最佳实践 https://old.reddit.com/r/ ...
- [转]ASP.NET Core Web API 最佳实践指南
原文地址: ASP.NET-Core-Web-API-Best-Practices-Guide 转自 介绍# 当我们编写一个项目的时候,我们的主要目标是使它能如期运行,并尽可能地满足所有用户需求. 但 ...
- 前端最佳实践——DOM操作
1.浏览器渲染原理 在讲DOM操作的最佳性能实践之前,先介绍下浏览器的基本渲染原理. 分为以下四个步骤: 解析HTML(HTML Parser) 构建DOM树(DOM Tree) 渲染树构建(Rend ...
- 基于springboot的web项目最佳实践
springboot 可以说是现在做javaweb开发最火的技术,我在基于springboot搭建项目的过程中,踩过不少坑,发现整合框架时并非仅仅引入starter 那么简单. 要做到简单,易用,扩展 ...
- WEB开发最佳实践
linux命令 man ls:显示ls的命令详情,man命令可以查具体的命令详情
- WEB前端工程师(实践)制作天气预报难度:简单
需要准备:jQuery Bootstrap 天气预报API(本文中使用API可能会失效请灵活运用) CSS样式可以你自己去写这里只提出jQuery 请求数据和解析JSON数据 { "resu ...
- web前端开发最佳实践笔记
一.文章开篇 由于最近也比较忙,一方面是忙着公司的事情,另外一方面也是忙着看书和学习,所以没有时间来和大家一起分享知识,现在好了,终于回归博客园的大家庭了,今天我打算来分享一下关于<web前端开 ...
随机推荐
- MyEclipse开发WebService教程
. 创建一个 webService 工程. 2. 创建一个普通 Java 类 3. 创建 webService 服务端 HelloJaxwsDelegate.java 的源代码如下: 4. 导 ...
- android.view.WindowManager$BadTokenException: Unable to add window -- token null is not for an application
原博客地址:http://aijiawang-126-com.javaeye.com/blog/662336 在Activity中newSpinner是我把mContext传入,但是出了 andr ...
- 循环中不要放入openSession()
for(Shop s:list) { System.out.println(s.getName()); String sql="select shopId,sum(ele_bank+ele_ ...
- org.hibernate.HibernateException: Could not parse configuration: /hibernate.cfg.xml
org.hibernate.HibernateException: Could not parse configuration: /hibernate.cfg.xml at org.hibernate ...
- LA 2218 (半平面交) Triathlon
题意: 有n个选手,铁人三项有连续的三段,对于每段场地选手i分别以vi, ui 和 wi匀速通过. 对于每个选手,问能否通过调整每种赛道的长度使得他成为冠军(不能并列). 分析: 粗一看,这不像一道计 ...
- 转:MVC 下导航超链接本页面高亮的一种解决方案
前言 导航高亮一直是一个让大家头疼的问题. 纯 Javascript 的话可以判断当前页面的地址和链接地址是否有关系. 这样的弊端就是自由度太低,MVC 下会出一定的问题 (MVC 下有默认的 Con ...
- Windows下FFmpeg快速入门
本系列文章导航 Windows下FFmpeg快速入门 ffmpeg参数解释 mencoder和ffmpeg参数详解(Java处理视频) Java 生成视频缩略图(ffmpeg) 使用ffmpeg进行视 ...
- cimge 这次能够图片大小尺寸
CImage imSrc,imDest;imSrc.Load(……);//读入原始图片imDest.Create(……)//创建新大小的图片imSrc.StretchBlt(imDest.GetDC( ...
- 【字符串处理】HDOJ-1020-Encoding
[题目链接:HDOJ-1020] 相邻字符,两两比较. #include<cstdio> #include<cstring> ; char sr[MAXN]; int main ...
- Oracle 课程七之分析和动态采样
课程目标 完成本课程的学习后,您应该能够: •引子—统计信息的作用 •如何收集统计信息 •系统统计信息 •对象统计信息—表.字段.索引统计信息 •动态采样 统计信息的作用 Optimizer st ...