《爪牙拉什代码技巧提示》是一款Android平台的应用。
软件名称 | 爪牙拉什代码技巧提示 | 软件平台 | Android |
---|---|---|---|
软件大小 | 3.14MB |
1.轩庭家居爪牙螺母参考报价:¥0.35 2.东靖五金爪牙螺母参考报价:¥0.30 3.冷镦四爪角钉爪牙参考报价:¥0.07 性价比最高推荐 &nb...
这个感觉是软件的问题,重新安装一下试试吧,如果还不行的话,建议拨打4000166166找客服给远程看看
这是你套的某一项子目没有选择工程量代码,选择后就好了,否则是计算不出工程量的。
GCL 构件代码应用技巧 说明: 斜体字表示在使用时要特别注意的地方 构件 名称 构件代码 代码解释 计算方法 应用技巧 楼层 构件 地下室外墙防 水面积 DXSWQFSMJ 该 代 码 用 于 计 算 建 筑 物 地 下 室 外 墙 面 的 防 水 面 积。 地下室(除了基础层和首 层的所有楼层) 的所有外 墙的外侧边的面积, 不计 算基础层的防水面积。 地下室外墙防水面积= 外墙皮外侧的长度×层 高。 防水高度算至首层地坪。 软件没有考虑外墙的门 窗洞口和突出外墙面柱 的因素。 如何计算基础层的外侧 防水面积?一般情况下, 基础层和最底层的地下 室外墙外皮位置是一样 的,因此可以使用最底层 的建筑外周长×图纸中 实际高度,就可以计算 了。如果满基侧面需要做 防水,那么可以使用满基 的模板面积来计算满基 侧面防水面积。 女儿墙中心线 长度 NEQZXXCD 女 儿 墙 的 总 长度。
1. 避免链式声明
后果:可能引入全局变量
//错误的写法
var a = b = 0;
这段代码中,b实际上被声明为全局变量。因为操作符优先级是是从右往左,所以该语句相当于:
var a = (b = 0)
此时b未声明就被直接赋值,所以b成了全局变量
2. 单一var原则
这条规则的意思是,把函数内部的所有变量,放到顶部声明。比如:
//示例
function A(){
var a = 1,
b = 2,
c = a + b ;
}
优点:
便于查找函数内部使用的局部变量 防止变量未定义时就被使用 防止变量声明提升后引发的误解关于第三点,这里举个例子说明:
var x = 1;
function A(){
console.log(x);//第一处输出,注意结果
var x = 2;
console.log(x);//第二处输出 2,没问题
}
从代码上看,第二处输出肯定没问题,可能会有人认为第一处输出的是1,因为此时在函数内部还没声明变量x,根据作用域链,向外层查找的话,x值为1。但是实际输出的值应该是undefined,因为js允许在函数任何地方声明变量,并且无论在哪里声明都等同于在顶部声明,这就是声明提升。所以上面的代码相当于:
var x = 1;
function A(){
var x;//提升到顶部
console.log(x);//此时已声明未赋值
x = 2;//赋值
console.log(x);
}
3. 使用for循环时,缓存长度值
通常用使用for循环遍历数组时,会采用以下写法:
for(var i = 0;i<arr.length;i++){
// 具体操作
}
这段代码存在的问题在于,在循环的每个迭代步骤,都必须访问一次arr的长度。如果arr是静态数值还好,但是我们在使用js时可能会碰到arr是dom元素对象,由于dom对象载页面下是活动的查询,这个长度查询就相当耗时,
//用len缓存长度值
for(var i = 0,len = arr.length;i<len;i++){
// 具体操作
}
按照上面的代码,我们在第一次获取长度值时就缓存这个长度值,就可以避免上述问题。
4. 使用for-in时,增加hasOwnProperty()判断
for-in通常用来枚举对象的属性和方法,但是这个方法会枚举范围包括对象和对象的原型对象(对原型对象不了解的可以看看我之前写的文章传送门)此时,利用hasOwnProperty()方法可以帮我们过滤出只在对象本身上的属性和方法,或者只在原型链的属性和方法
for(var key in obj){
if(obj.hasOwnProperty(key)){
// 对象本身的属性或者方法
}
else{
// 原型链的属性和方法
}
}
/* 下面是一个具体的例子 */
function A(name){
this.type = 'A类';
this.name = name || '未命名'
}
var a = new A('a');
function B(name){
this.subtype = 'B类';
}
// 建立原型链
B.prototype = a;
B.prototype.sayHello = function(){}
var b = new B();
// 遍历属性
for(var key in b){
//对象自身属性
if(b.hasOwnProperty(key)){
console.log('对象自身的属性或方法:'+key)
}
//上述表达式的另一种写法
if(B.prototype.hasOwnProperty.call(b,key)){
console.log('对象自身的属性或方法:'+key)
}
else {
console.log('原型链的属性或方法:'+key)
}
}
5. 使用===代替==
这个算是比较常见的了,因为js在做比较判断时,会执行强制类型转换,比如false == 0返回true这样的情况,使用===可以执行严格的等价比较,更易于阅读代码(后来阅读的人就不需要判断这个是遗漏还是故意使用强制类型转换简写)
6. 使用parseInt()时,带上第二个参数。
parseInt()用于从字符串中获取数值,第二个参数代表进制,默认是10。我们在使用的时候可能习惯性忽略这个参数,但是在一些情况下会有问题:当字符串的开头为0时,在es3里会被当做是八进制,es5里面仍然当做10进制,为了代码的一致性以及避免不必要的失误,应该每次使用时都带上参数:
var x = parseInt('089',10);//使用时都带上进制参数
7. 大括号的使用
大括号的使用主要是2个方面:
第1,不要省略大括号,即使可以忽略,比如:for(var i =1;i<10 ;i++)
console.log(i) //此处原则上可以忽略大括号
上述语句并没有问题,但是如果后期函数体内增加了其他语句的时候,很容易忘记补上大括号,因此建议都带上大括号;
第2,大括号的必须跟在前一个语句的同一行这个地方为什么加粗了呢?因为这个问题非常容易被忽略,通常我们都觉得大括号是跟在语句的同一行还是下一行只是习惯问题,但是实际上不是的!看下面这个例子:
function func(){
return
{
name:'xxx'
}
}
var res = func()
console.log(res)//输出undefined
是不是觉得很奇怪,看代码第一感觉应该是输出一个包含name属性的对象。请注意,由于js的分号插入机制:如果语句没有使用分号结束,会自动补充分号,因此上面的代码实际相当于如下写法:
function func(){
return undefined;//自动插入分号
{
name:'xxx'
}
}
正确的写法应该是:
function func(){
return {
name:'xxx'
}
}
var res = func()
console.log(res)//输出{name:'xxx'}