###目录:
- JavaScript
- HTML
- CSS
- example
###JavaScript (1)使用 === 和 !== 判等;不要使用 == 和 != 判等;
if(word === str)
(2)if(变量)足够判断变量是否为null、 '' 、undefine等情况;不用依次判断;
var name = getJSON().name; //这里不知道是否能取到,如果属性层次较深,建议使用getJSON()['name']
if(name){ //简约判断
.......
}
(3)能在函数作用域内声明的变量,不要放在作用域外面;
var domain = 'xx.com'; //共享变量
var getLBSObj = function(){
//下面的变量没有必要暴露在外面,仅供该方法使用
var name = 'LBS',
desc = '基于LBS的应用',
api = ['JS', 'android', 'iOS'];
....
}
(4){}的位置紧随对象和函数,例如var getName = function(){
var getName = function(){
var name = '大世界,小流量';
...
return name;
}
(5)js大体兼容IE8+,例如使用JSON,当然可以使用 (new Function("return " + str))();向下兼容
var getJSONObj = function(jsonStr){
if(JSON && JSON.parse)
return JSON.parse(jsonStr);
return (new Function('return' + jsonStr))();
}
(6)字符串全部使用单引号,例如 var str = 'id="result" name="address"';
var div = document.createElement('div');
div.innerHTML = '<div id="news">conetnt...</div>';
(7)所有变量和表达式间空一格,例如for(var index in nameArr){, for(var i = 0, n = nameArr.length; i < n; i++){
var name = 'Github';
var apiArr = ['JavaScript API', 'iOS SDK', 'Android SDK'];
// ++i或者i++ 在严格模式下,可写成i += 1;
for(var i = 0, n = apiArr.length; i < n; ++i){
console.log(apiArr[i]);
}
(8)变量的命名需要见名知意,例如 var driverInfo = JSON.parse(jsonStr);
var tipInfo = '请输入提示语'; //good case
var str1 = '请输入提示语'; // base case
(9)所有变量的声明在逻辑块的最前部
var SERVER_URL = 'http://127.0.0.1:3000/amap/js'; //常量
var user = new User(); // global variable
//使用上面的全局变量
var setName = function(){
getJSON(SERVER_URL + '/user/get');
...
}
//一下变量被下面2个函数使用,而不被上面的函数使用,建议变量定义在逻辑块上面
//下面2个函数算是一个逻辑块
var name = 'xxxx';
var locationHash = 'nearby';
var setPath = function(id){
location.hash = locationHash + '/' + name + '/' + id;
}
var getData = function(pid){
getJSON(SERVER_URL + '/' + name + '/' + pid);
}
(9) return 后面变量不要换行,因为压缩会引起很多问题
(function(){
return { //这里不要换行
name: '测试服务', //注意name和value之间有空格
url: 'test:3000'
};
})();
(10)建议使用 && 、 || 、!!(obj)、三元运算符等
if(data && data.length) //这是合理的判断,&&是依次判断,遇否中断, 建议
var name = data.name || ''; //依次都判断,遇true赋值,建议
var isName = names.split(',').lenght > 1 ? '名称正确': '名称错误';
var isCanvas = !!(canvas.getContext('2d'));
(11)所有callback建议return
function getData(url, callback){
....
getJSON(url, function(status, data){
if(status){
var data = JSON.parse(data);
data.status = status;
return callback(data);
}
return callback({
status: 0
});
});
}
(12)建议所有数组声明,使用[],例如 var arr = [];
var names = new Array(); //不建议
var names = []; //建议
(13)++和--等一元自操作运算符紧跟变量
i++; //建议
++i; //建议
i ++; //不建议
++ i; //不建议
(14)注释,建议单行注释;注释为单独一行
//创建用户(这是单行注释,且占据一行)
var user = new User('xiaoming', 25);
//设置用户姓名
user.setName('鬼谣');
(15)语句统一使用分号';'结尾,建议 var getName = function(){ ... }; //这里有分号
(16)所有的JavaScript代码放在一个闭包内,避免污染全局变量
(function(exports){
var user = new User();
//do something
...
})(window);
###HTML (1)统一使用HTML5的DOCTYPE
<!DOCTYPE html>
(2)使用UTF8字符编码,全部简写成如下即可
<meta charset="utf-8" />
(3)id紧跟标签名(空一格),即id放在标签属性的最前面
<div id="" name="" ...></div>
(4)JavaScript外部引用脚本全部放在body闭合标签上;不放在head里面
<!DOCTYPE html>
<html ng-app="app">
<head>
<meta charset="utf-8" />
<title></title>
</head>
<body>
<div></div>
<script type="text/javascript" src="js/angular.min.js" ></script>
<script type="text/javascript" src="lib/1.js" ></script>
</body>
</html>
(5)css文件,公共样式放入common.css, 其他内联到head标签内部
<head>
<meta charset="utf-8" />
<title></title>
<link rel="stylesheet" href="css/common.css" />
<style type="text/css">
html body{...}
body>div:nth-child(2){...}
</style>
</head>
(6)建议减少使用table、H等标签,如果有必要使用display: table;建议全部使用DIV+CSS布局
(7)HMTL文件中的标签属性全部使用双引号
<body>
<div id="parent">
<div id="detail">
</div>
</div>
</body>
(8)HTML标签内不建议内联样式
<!--不建议内联样式-->
<div style="color:#ccc; font-size:14px;"></div>
(9)保持HTML文件的干净,看上去清爽,只剩下标签和class属性最好
(10)scrip标签标准格式,建议不使用language
<script type="text/javascript" src="外部脚本" ></script>
###CSS (1)所有样式都必须分号(';')结尾, 标签和样式都在一行,不换行,减少页面代码行数
html body{font-size:12px;color:#ddd;}
body>div:nth-child(2){width:300px;height:300px;border:1px solid red;}
(2)所有样式尽量使用class、标签表示;减少使用id
/*一篇HTML中尽量看去只用class,必要id除外*/
.fl{float:left;}
/*尽量减少使用id*/
#title_text{float:left;}
(3)如果兼容低版本浏览器,建议不带前缀的css在前,然后是带前缀的样式,毕竟高版本浏览器居多
div{transform: ...;-webkit-transform: ...;-moz-transform: ...;-ms-transform: ...;}
(4)css内部属性字符串使用单引号
html body{font-size:12px;color:#ddd;font-family: '微软雅黑', georgia;}
(5)提示信息,字体为12px; 按钮字体为14px(只针对js-demo)
(6)css外部脚本标准为
<link rel="stylesheet" href="css/common.css" />
###Example 下面是一个简单的地图显示的demo,代码如下:
<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<title>地图显示</title>
<style type="text/css">
body{margin:0;height:100%;width:100%;position:absolute;}
#mapContainer{height:100%;width:100%;}
</style>
</head>
<body>
<div id="mapContainer"></div>
<script type="text/javascript" src="http://webapi.amap.com/maps?v=1.3&key=8e332545f5be046f134095019aa8b5cb"></script>
<script type="text/javascript">
(function(AMap){
var map = new AMap.Map('mapContainer', {
resizeEnable: true,
rotateEnable: true,
dragEnable: true,
zoomEnable: true,
//设置可缩放的级别
zooms: [3,18],
//传入2D视图,设置中心点和缩放级别
view: new AMap.View2D({
center: new AMap.LngLat(116.397428, 39.90923),
zoom: 13
})
});
//以下为缩放逻辑代码块,地图的最小级别不能小于4
//跟逻辑块相关的变量定义,定义在逻辑块最前部
var MIN_ZOOM = 4;
function setZoom(zoom){
if(zoom >= MIN_ZOOM)
map.setZoom(zoom);
}
setZoom(18);
})(AMap);
</script>
</body>
</html>