日常工作bug总结

1.在使用jQuery的text()与val()使用时,如果按钮是<button></button>的形式使用text()写入时,在IE8下会出现延迟,即我在写定时器5秒倒计时写入button标签时,5,4,3,2,1,中的4有时出现不了,解决方法是使用<input type="button" value="">按钮代替button标签,使用val()写入。所以在写入时有变量则要选择使用input按钮。例:oBtn.val(i);

 

2.在使用opacity: 0.1;filter: alpha(opacity=10);(IE下一一般会使用滤镜) 父元素使用透明度时会使子元素也产生透明,解决方法是使俩元素的父子关系转化为兄弟关系。在使用    background:rgba(51,51,51,0.1);设置透明时不会使子元素发生透明,但只支持IE9+。

 

3.jquery的height()无法获得可视区的高度,使用原生JS的clientHeight。

可以:$('window').height();

兼容写法

if(document.compatMode == "BackCompat") {//渲染方式
    wHeight = document.body.clientHeight;
}else {//"CSS1compat"
    wHeight = document.documentElement.clientHeight;
}

 

4.max-width一般与下面几个属性一起使用

max-width: 300px;
overflow:hidden;
white-space:nowrap;
text-overflow: ellipsis;

当页面超出范围时显示...。

 

5.关于CDN

CDN是Content delivery network(内容分发网络)的简称,这一技术以往只应用于大型商业性网站。通过使用这种技术,可以将网站上的静态内容(例如.html文件、.jpg图片)和动态内容(例如数据库查询)缓存到CDN提供商位于全球各地的多个服务器上。这样当全世界不同访客访问这个网站的时候,就不再需要通过网站所在服务器读取这些内容,而是可以从就近的CDN缓存服务器上读取,因此内容的读取速度更快,直接影响就是网页的加载速度更快。

 

6.em,px,rem

如果设置body的font-size的大小为24px;子元素字体大小设置为0.5em则字体大小为12px

rem只支持IE8以上的浏览器(不包括IE8),当使用 rem 单位,他们转化为像素大小取决于页根元素(html)的字体大小

 

7.文档碎片(减少页面重绘重排)

<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<title>文档碎片</title>
</head>
<body>    
<script>
    var temp = document.createDocumentFragment();//文档碎片(当把文档碎片付给某节点时,只是把文档碎片中的子节点付给了某节点,它本身并没有插入到这个节点中)
    for (var i=0; i<100; i++) {
        var test =document.createElement('div');//创建一个节点
        test.innerHTML = 'aaa' + i;//给节点添加内容
        temp.appendChild(test);//把创建的节点插入到temp文档中
    }
    document.body.appendChild(temp);//把temp文档插入到body末尾
</script>
</body>
</html>
</html>

 

8.box-sizing: border-box;

当给元素设定宽高时,设置border,padding不改变其宽高的大小。即IE盒模型。与之相反的是标准盒模型(boz-sizing: content-box;)。

 

9.通过

function getByClass(oParent,sClass){
	var aEle=oParent.getElementsByTagName("*");
	var i=0;
	var aResult=[];
	for(i=0;i<aEle.length;i++){
		if(aEle[i].className==sClass){
			aResult.push(aEle[i]);
		}
	}
		return aResult;
}

例:var aLi = getByClass(xx,‘xx’);

aLi是一个数组,获取的是一个唯一值时要用aLi[0]获得。

 

10.俩个二级域名http://user.cliim.net与http://biz.cliim.net/,其中一个设置的cookie在另一个获取不到,所以要将cookie设置在一级域名http://cliim.net下

var SetCookievar = function(name,value,domain){
  document.cookie = name + "="+ escape (value) +";domain=" + domain;
}

domain为cliim.net而不是http://cliim.net。

可通过正则表达式获取var domain = window.location.host.replace(/(biz\.)|(user\.)/, "");

http://baidu.com/a与http://baidu.com/b同理。

获取方式:url.replace(/http:\/\/.*?([^\.]+\.(com\.cn|org\.cn|net\.cn|[^\.]+))\/.+/, "$1"));

 

11.IE7提示升级

document.documentMode:IE多少则返回多少。

 

12.判断某元素是否含有子元素:

if(this.model.children&&this.model.children.length){}

 

13.如何判断是否获取到jquery对象

$("#XXXX").length != 0

 

14.谷歌高清屏背景图片的添加方式

background-image: url('/cli/images/user_plugin_service_head_bg_1x.png');
background-image: -webkit-image-set(url('/cli/images/user_plugin_service_head_bg_1x.png') 1x,url('/cli/images/user_plugin_service_head_bg_2x.png') 2x);

 

15.对某内联元素使用定位时,会将其从内联元素变为块元素(只有块级元素才可以使用定位),width的长度不再是文字的长度

 

16.JSON.parse():JSON字符串转化为JSON对象

JSON.stringify():JSON对象转化为JSON字符串

 

17.关于字符编码

一个字节有八位,可以表示2^8=256个字符,而ASCLL码有128个字符,英文字符可以用这128个字符表示,所以一个英文字母代表一个字节,但中文有十万多个字,并不能用256个字符表示,所以会用gb2312,即用俩个字节表示
,表示的字数可以为256*256=65536个字符。
在128到256之间空的位置不同的编码方式存放不同的字符,Unicode则编码使用唯一的编码,即不会产生乱码,
utf-8是Unicode的一种方式。
Unicode例\u7528,可以用console.log直接输出
URL在进行get请求时会对汉字进行编码,使用decodeURIComponent()对汉字进行解码
编码函数是encodeURIComponent()
对整个URL进行编码:encodeURI()
解码:decodeURI()

 

18.$_each()的使用

$_each($('li'), function(i, n) {

  console.log(i + n);

  //其中i表示第几个$('li'),n表示该$('li');

})

 

19.关于get与post的区别

一般的我们都认为是一下的三个区别

1. GET使用URL或Cookie传参。而POST将数据放在BODY中。(没有规定get请求一定要放在url中,post一定要放在body中)

2. GET的URL会有长度上的限制,则POST的数据则可以非常大。(URL过长会对服务器产生负担,是对http请求的限制)

3. POST比GET安全,因为数据在地址栏上不可见。(不正确)

但以上的理解这只是HTML标准对HTTP协议的用法的约定。不能当成GET和POST的区别。

他们只有一点根本区别,简单点儿说,一个用于获取数据,一个用于修改数据。

参考博客:http://www.cnblogs.com/nankezhishi/archive/2012/06/09/getandpost.html

 

20.事件委托如何获取父级ID

<li id="goSomewhere">
<div id="div1">2121212</div>
<div id="div2">21212121</div>
</li>

在事件委托里,点击goSomewhere里的代码获取target.id会得到div1或div2,如何获得goSomewhere,

使用css:

#goSomewhere > *{
  pointer-events: none;
}

元素永远不会成为鼠标事件的target

 

21.关于vertical-align

<!DOCTYPE html>
<html lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html;charset=utf-8" >
    <title></title>
    <style type="text/css">
    * {
        padding: 0;
        margin: 0;
    }
    .box {
        background:green; 
        color:white; 
        padding-left:20px;
        height: 100px;
        padding-top: 20px;

    }
    .dot {
        display:inline-block; 
        width:80px; 
        height:30px; 
        vertical-align: middle;
        line-height: 30px;
        background-color: red;
    }
    </style>
</head>
<body>
    <div class="box">
        <span class="dot">伊的文字</span>
        我是一段卡哇伊的文字.
    </div>
</body>
</html>
<!-- http://www.w3school.com.cn/tiy/t.asp?f=csse_vertical-align -->
View Code

vertical-align:middle;红色背景的文字居中是相对于右边这段文字的,并只适用于内联元素,还有top、text-top、bottom、text-bottom等属性值。

 

22.关于return的使用

function test(x, y) {
    for(var i = 0; i < x; i++) {
        for(var j = 0; j < y; j++) {
            if(i * j == 25) {
                return;
            }
        }
    }
}
test(10, 10);

当i * j等于25时,直接跳出整个test()函数。

 

23.新的循环方式

  function test() {
        var arrs = ['a', 'b', 'c', 'd'];
        for(var i = 0, arr; arr = arrs[i++];) {//最后有个分号
            console.log(arr);
        }
    }
    test();//a, b, c, d            

 

24.JS中手动触发事件,IE下使用fireEvent,非IE下使用dispatchEvent

<!DOCTYPE html>
<html lang="en">
    <head>
      <meta charset="utf-8" />
      <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
      <title>fireKeyEvent</title>
    </head>
    
    <body>
        <input type="text" id="txt1"/>
        <input type="button" id="btn1" value="fire"/>
        
        <script type="text/javascript">
            function $(id){
                return document.getElementById(id);
            }
            
            function addEvent(el, type, fn){
                if(document.addEventListener){
                    el.addEventListener(type, fn, true);
                }else if(document.attachEvent){
                    el.attachEvent("on"+type, fn);
                }else{
                    el["on"+type] = fn;
                }
            }
            
            
            function fireKeyEvent(el, evtType, keyCode){
                var evtObj;
                
                if(document.createEvent){//非IE下使用dispatchEvent
                    if( window.KeyEvent ) {
                        evtObj = document.createEvent('KeyEvents');
                        evtObj.initKeyEvent( evtType, true, true, window, false, false, false, false, keyCode, 0 );
                    } else {//
                        evtObj = document.createEvent('UIEvents');
                        evtObj.initUIEvent( evtType, true, true, window, 1 );
                        delete evtObj.keyCode;
                       
                        if(typeof evtObj.keyCode === "undefined"){
                            Object.defineProperty(evtObj,"keyCode",{value:keyCode});
                        }else{
                            evtObj.key=String.fromCharCode(keyCode);
                        }
                    }

                    el.dispatchEvent(evtObj);
                    
                }else if(document.createEventObject){//IE下使用fireEvent
                    evtObj = document.createEventObject();
                    evtObj.keyCode=keyCode
                    el.fireEvent('on'+evtType, evtObj);
               }
            }
            
            addEvent($("txt1"), "keydown" ,function(e){
                var evt=window.event || e;
                var keyCode=evt.keyCode || evt.key.charCodeAt(0);
                alert("keyCode:"+keyCode);
            })
            
            
            addEvent($("btn1"), "click", function(){
                fireKeyEvent($("txt1"), "keydown", 27);
            });
            
        </script>
    </body>
</html>

 

25.如何使div中的字体居中:内层div的line-height等于外层div的高度。

 

26.div的position设置为fixed;元素脱离文档流,设置width:100%;时,width的宽度为页面的宽度。

 

27.url-prefix:火狐浏览器独有的属性

/*Firefox实现效果*/
 @-moz-document url-prefix(){    /*@-moz-document url-perfix(){}是firefox的一个独有属性,只有firefox浏览器能识别,也可以说是一种hack*/
   .text-overflow span {
     max-width: 70px;/* 在FF下改变内容宽度,用来放置:after增加的内容(...)*/
     float: left;/*进行浮动*/
   }
 }
 @-moz-document url-prefix(){    
   /*利用:after增加(...)省略符*/
   .text-overflow:after {
      content:"...";/*增加省略符号*/
      float: left;/*设置浮动*/
      width: 25px;/*省略符宽度*/
      padding-left: 5px;/*省略符内距,用来拉开内容之间的距离*/
      color: #000;
   }
 }

 

28.实现博客中的文章内容超出固定宽高度后显示。。。及添加确定全文按钮:

<!DOCTYPE html>
<html lang="en">
    <head>
      <meta charset="utf-8" />
      <title>fireKeyEvent</title>
      <style type="text/css">
      *{
        padding: 0;
        margin: 0;
      }
      #div1  {
        width:300px;
        height: 90px;
        overflow: hidden;
        display: block;
        position: relative;
      }
      .text:after {
          content:"...";/*增加省略符号*/
          width: 100px;/*省略符宽度*/
          padding-left: 5px;/*省略符内距,用来拉开内容之间的距离*/
          color: #000;
          position: absolute;
          right: 0;
          bottom: 0;
          background-color: white;
      }
      #btn {
        position: absolute;
        right: 0;
        bottom: 0;
      }
      </style>
    </head>
    <body>
    <div id="div1" >
        <p class="text">I am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boyI am a boy</p>
        <button id='btn'>阅读全文</button>
    </div>
</html>
View Code

 

29.文字超出固定宽度后显示。。。

css代码:

.aaa{
  width: 100px;
  height: 20px;
  white-space: nowrap;//强制不换行
  text-overflow: ellipsis;//显示省略号          
}

 

30.#div1 div 与 #div > div的区别

#div1 + div是指#div1相邻元素的下一个元素,俩者必须紧挨着,不能有其他标签隔开。

#div1 div是指#div1下的所有div

#div1 > div是指子元素的div

 

31.单选框与右边的文字对齐使用vertical-align: -2px;

<label><input type="checkbox" name="confirm" style="vertical-align: -2px;">阅读并接受协议</label>

 

32.判断JS的值存不存在

如果只判断对象是否存在,则使用if (typeof myObj == "undefined") {}

如果除了对象是否存在,还要判断对象是否有null值,则使用if (!myObj) {}

 

33.表单写入的按回车会使表单提交并刷新页面。

 

34.jquery中的on事件可以绑定动态加载的html代码的DOM(即可以绑定通过ajax获取的html代码),但无法绑定通过ajax获取的代码,在通过ajax获取(例如在ajax获取的代码中使用ajax实现搜索功能重新生成的html代码)。解决方法是使用事件委托。

 

35.jquery中的has()方法: $('ul').has('li').length ? 'yes' : 'no';

     jquery中的eq()方法: $('ul li').eq(0).attr('class');//className是原生的JS属性

 

36.

关于前端的字符转义
前端如文本框在输入字符,经过后台存入数据库,此时的字符不做转义处理
当前端需要从后台读取字符时,后台返回的字符需要经过转义处理
例:前端输入&符号,后台存到数据库中的也是&符号,当前端去获取数据的时候,后台就需要将&符号转义成&amp;输出,
前端接收到之后解析成&符号。
前端输入&amp;符号,后台存到数据库中的也是&amp;符号,当前端去获取数据的时候,后台就需要将&amp;符号转义成
&amp;amp;输出,前端接收到之后解析成&符号。
后台通过函数过滤字符
一般需要解析的字符为& \\ < > '等

 

37.thinkphp insertFields,$updateFields中逗号后不能加空格

38.click事件里绑定click事件多次点击之后会多次绑定

例:二次确认删除

    $('#idcode_members').on('click', '.delete', function() {
        $('#delete_submit').unbind();//为避免在$('#delete_submit")上绑定多次事件,需要对其进行清除
        var idcode_id = $(this).attr('idcode_id');
        var list_box_parent = $("#dcode_list_" + idcode_id);
        $('#delModal').modal('show');
        $('#delete_submit').on('click', function() {
            $('#loading-wait').show();
            deleteData(idcode_id, list_box_parent);
        });
    });

  

 39.ajax同步与异步

jquey中的$_ajax中的参数async为true时代表异步请求,false时为同步请求,默认为true。
同步请求会阻塞代码,只有当获取到返回值时才会执行之后的代码,异步请求则不需要请求结果的返回就可以执行之后的代码,不会造成阻塞。

 

40.谷歌浏览器支持的最小字体为12px,小于12px则需要使用图片代替。

 

41.date与data的区别

data代表数据,date为时间。new Date();

 

42.jquery中获取或设定checked、disabled需要用prop,而不能用attr。

具有 true 和 false 两个属性的属性,如 checked, selected 或者 disabled 使用prop(),其他的使用 attr()。

在jquery源码中attr通过使用的 DOM 的 API setAttribute() 和 getAttribute() 方法操作的属性元素节点。通过节点设值。

prop使用 document.getElementById(el)[name] = value,这是转化成 element 的一个属性。通过对象设值。

通过attr获取check时会返回checked,而不是true,false。

 

43.闭包不会造成内存泄漏。程序写错了才会造成内存泄漏。老版本的内存泄露是由于浏览器自身的bug

 

44.vuejs中的{{{}}}的输出

在网站上动态渲染任意 HTML 是非常危险的,因为容易导致 XSS 攻击。记住,只对可信内容使用 HTML 插值,永不用于用户
提交的内容。

 

45.JSON的数据语法可以表示成以下三种类型的值

1.简单值
字符串、数值、布尔值、null但不包括undefined。
2.对象
{
"aa": "aa",
"bb": "bb"
}
3.数组
[{},{},{}]

 

46.

单选框居中
<label style="position: relative;">
<input type="checkbox" style="position:absolute; left: 0px; top: 2px; margin-left: 20px;">同时发送电子名片到
他的邮箱
</label>
使用定位的方式布局

 

47.

判断复选框是否被选中及如何点击文字选中复选框
选择已经勾选的复选框$(".checkbox:checked")
判断复选框是否勾选if($("#chencked").is(":checked")) {}
label标签的for属性去除后即可点击文字选中复选框或者for等于checkbox的id值不是name值

 

48.

图片居中

*{
    padding: 0;
    margin: 0;
}
#main {
    width: 500px;
    height: 500px;
    background-color: red;
    display: table;
}
#table {
    display: table-cell;
    vertical-align: middle;
}
#content {
    width: 100px;
    background-color: yellow;
}
<div id="main">
    <div id="table">
        <div id="content">
            <p>sasasasas</p><br>
            <p>sasasasas</p>
            <p>sasasasas</p><br>
            <p>sasasasas</p>
            <p>sasasasas</p><br>
            <p>sasasasas</p>
            <p>sasasasas</p><br>
            <p>sasasasas</p>
            <p>sasasasas</p><br>
            <p>sasasasas</p>
            <p>sasasasas</p><br>
            <p>sasasasas</p>
        </div> 
    </div>
</div>

  

posted @ 2016-05-12 14:41  PLDaily  阅读(802)  评论(0编辑  收藏  举报