典藏百度前端面試題

1. UI設計部分javascript

   這是web產品化的第一步。這個部分一般在稍大型的公司裏,被單獨設立爲一個部門或者一些人來工做。主要是要掌握Photo, AI,能夠很快的將創意轉化爲平面設計圖,並製做PNG等小圖片。 同時,UI設計還要預包含用戶交互設計的元素,如何和用戶交互的基本原型等。php

2. HTML/CSS,頁面靜態化css

這是web產品化的2步,就是將UI設計師的設計圖切成靜態頁面。這裏的「切」不是單純的切,而是使用css裏面背景色和邊框樣式等方式對設計原稿 進行解讀,並造成符合web標準的html代碼。這裏web前端還須要將圖片、html頁面以及css樣式進行合理的文件分佈安排等html

3.Javascript, AS 客戶端動態化前端

這是web產品化的3步,工程師使用DOM操做、AJAX,實現數據和服務端的通訊以及本地樣式的切換。同時,因爲Javascript、 AS是一門動態語言,因此這部分的編碼要求web前端工程師有較好的編碼習慣,能寫高效率的OOP代碼,並對代碼進行壓縮上線以下降帶寬消耗等。java

4.Flash、Silverlight、Video    多媒體化node

這部分針對不一樣web產品有不一樣的要求,一般要求是可使用Flash和web、Server進行交互,並對Flash進行設計與開發。web

5.PHP、Java等CGI, 服務端通訊基本知識和編碼ajax

這部分主要是更好的使用Ajax等技術,瞭解服務端的工做方式將更有利於web前端工程師工做的開展。一般優秀的web前端工程師都是對服務端的一 種開發語言很瞭解。正則表達式

6.web開發腳本開發環境用什麼、調試用什麼
試過aptana,如今就用editplus
調試確定用firebug,ie下看頁面DOM用IEInspector
web前端產品的開發流程
答:首先根據產品的定位、用戶羣,肯定配色,而後紙上設計總體佈局,而後png或者psd出效果圖,切出須要的小圖片,而後手寫代碼div+css構造出 頁面,而後根據功能寫腳本參考126郵箱首頁,將全部小圖片放到一個圖片中,經過css的background-position實現頁面,仍是爲了優化,減小http鏈接數

規避javascript多人開發函數重名問題
答:首先是經過命名規範,好比根據不一樣的開發人員實現的功能,在函數名加前綴,雖然函數名看起來複雜,發佈的時候仍是能夠替換,從而優化。
還有一種辦法是,每一個開發人員都把本身的函數封裝到類中,而後調用的時候即便函數名相同,可是由於是要類.函數名來調用,因此也減小了重複的可能性。

IE、FF下面CSS的解釋區別
答: 1.png透明背景,FF下面沒有問題,IE須要用濾鏡通道
2.z-index在IE、FF下面的解釋問題,

IE會認爲第一個z-index=0
3.長字符串,word-wrap:break-all能夠解決IE,可是FF須要overflow:hidden才行

一、有些標籤在ff中不能用,好比button
二、濾鏡
三、鼠標cursor:hand cursor:pointer
四、div的高度自適應
五、對box模型解析不同
六、ul、ol的padding和margin

IE都能識別*,標準瀏覽器(如FF)不能識別*;
IE6能識別*,但不能識別 !important;
IE7能識別*,也能識別 !important;
FF不能識別*,但能識別 !important;
例如style=」*width:10px;!important width:20px;」
這樣在IE6下寬度爲10px,在IE7下寬度時20px

web前端技術的展望
答:javascript ajax;flash AS;Flex;Silverlight
4用腳本寫去除字符串的先後空格

String.prototype.trim = function(mode)
{//先後去空格
if (mode==’left’) {
return ((this.charAt(0) == 」 「 && this.length > 0) ? this.slice(1).trim(’left’) : this);
} else
if (mode == ’right’) {
return ((this.charAt(this.length - 1) == 」 「 && this.length > 0) ? this.slice(0, this.length - 1).trim(’right’) : this);
} else {
return this.trim(’left’).trim(’right’);
}
};

附上javascript正則表達式的基本知識:
g: 全局匹配
i: 忽略大小寫
^ 匹配一個輸入或一行的開頭,/^a/匹配」an A」,而不匹配」An a」
$ 匹配一個輸入或一行的結尾,/a$/匹配」An a」,而不匹配」an A」
* 匹配前面元字符0次或屢次,/ba*/將匹配b,ba,baa,baaa
+ 匹配前面元字符1次或屢次,/ba*/將匹配ba,baa,baaa
? 匹配前面元字符0次或1次,/ba*/將匹配b,ba
(x) 匹配x保存x在名爲$1…$9的變量中
x|y 匹配x或y
{n} 精確匹配n次
{n,} 匹配n次以上
{n,m} 匹配n-m次
[xyz] 字符集(character set),匹配這個集合中的任一一個字符(或元字符)
[^xyz] 不匹配這個集合中的任何一個字符
[b] 匹配一個退格符
b 匹配一個單詞的邊界
B 匹配一個單詞的非邊界
cX 這兒,X是一個控制符,/cM/匹配Ctrl-M
d 匹配一個字數字符,/d/ = /[0-9]/
D 匹配一個非字數字符,/D/ = /[^0-9]/
n 匹配一個換行符
r 匹配一個回車符
s 匹配一個空白字符,包括n,r,f,t,v等
S 匹配一個非空白字符,等於/[^nfrtv]/
t 匹配一個製表符
v 匹配一個重直製表符
w 匹配一個能夠組成單詞的字符(alphanumeric,這是個人意譯,含數字),包括下劃線,如[w]匹配」$5.98″中的5,等於[a-zA- Z0-9]
W 匹配一個不能夠組成單詞的字符,如[W]匹配」$5.98″中的$,等於[^a-zA-Z0-9
舉例:驗證email
var myReg = /^[_a-z0-9]+@([_a-z0-9]+.)+[a-z0-9]{2,3}$/;
if(myReg.test(strEmail)) return true;

1.       如何顯示/隱藏一個DOM元素?
; s5 i1 n+ g2 c更改元素的css style,設爲display: none。此外還能夠將visibility設爲hidden,透明度設爲0,或長、寬設爲0。. `7 m: r9 n$ u7 k& ]
2.       一個定寬網頁在瀏覽器(IE6,IE7,Firefox,IE5)中橫向居中對齊的佈局,請寫出主要的HTML標籤及CSS。 

 

3.       CSS中margin和padding的區別$ Q& n1 o  \) P0 |' ]
margin是外邊距,屬於元素以外,相鄰元素的margin能夠融合。4 W5 _+ M1 V  J) I. e3 E2 V, P
padding是內邊距,在元素以內,相鄰元素的padding不可融合。) @2 V9 W1 X7 {7 Y
4.       JavaScript中如何檢測一個變量是一個String類型?請寫出函數實現3 ^5 H3 {  |2 v7 E5 F5 x
function(obj) {; Z% ]6 f0 J: x5 W  t5 x
return typeof(obj) == 」string」;$ B8 P9 B' c' ?: A
}
 I) |+ t, P
6.       如何控制網頁在網絡傳輸過程當中的數據量; G- i- a  q) \3 t# j$ _1 R
0 }) }# p( @- ~
 Q2 _5 [  x4 g8 k, e" r2 b
8.       Linux中,將a、b打包爲back.tar,命令是(  )
  不知道,,,;n u3 p4 _6 `
9.       Flash、Ajax各自的優缺點,在使用中如何取捨?# h1 L% |/ p8 W
Flash的缺點是須要客戶端安裝Flash插件,比較大,且更改了默認的HTML頁面行爲;但能夠方便地實現不少特效及動畫,且具備較高權限。
Ajax的缺點是編程較爲複雜,須要服務器端的支持,能實現的效果只能是DOM API提供的,權限很低,較難跨域;但能夠顯著加快頁面的載入速度和用戶體驗。
此外,兩者都不能被搜索引擎索引(Google已支持Flash文本的索引),不利於SEO。
重要和關鍵部分直接用HTML,交互部分可使用Ajax,複雜的動畫可採用Flash。

 

1, 判斷字符串是不是這樣組成的,第一個必須是字母,後面能夠是字母、數字、下劃線,總長度爲5-20

var reg = /^[a-zA-Z][a-zA-Z_0-9]{4,19}$/;

reg.test("a1a__a1a__a1a__a1a__");

2,截取字符串abcdefg的efg

var str = "abcdefg";

if (/efg/.test(str)) {

  var efg = str.substr(str.indexOf("efg"), 3);

  alert(efg);

}

3,判斷一個字符串中出現次數最多的字符,統計這個次數

//將字符串的字符保存在一個hash table中,key是字符,value是這個字符出現的次數

var str = "abcdefgaddda";

var obj = {};

for (var i = 0, l = str.length; i < l; i++) {

   var key = str[i];

   if (!obj[key]) {

      obj[key] = 1;

   } else {

      obj[key]++;

   }

}

 

/*遍歷這個hash table,獲取value最大的key和value*/

var max = -1;

var max_key = "";

var key;

for (key in obj) {

   if (max < obj[key]) {

      max = obj[key];

      max_key = key;

   }

}

 

alert("max:"+max+" max_key:"+max_key);

4,IE與FF腳本兼容性問題

(1) window.event:

表示當前的事件對象,IE有這個對象,FF沒有,FF經過給事件處理函數傳遞事件對象

(2) 獲取事件源

IE用e[「srcElement」] 獲取事件源,而FF用e[「target「] 獲取事件源

(3) 添加,去除事件

IE:element.attachEvent(「onclick」, function) element.detachEvent(「onclick」, function)

FF:element.addEventListener(「click」, function, true) element.removeEventListener(「click」, function, true)

(4) 獲取標籤的自定義屬性

IE:div1.value或div1[「value」]

FF:可用div1.getAttribute(「value」)

(5) document.getElementsByName()和document.all[name]

IE;document.getElementsByName()和document.all[name]均不能獲取div元素

FF:能夠

(6) input.type的屬性

IE:input.type只讀

FF:input.type可讀寫

(7) innerText textContent outerHTML

IE:支持innerText, outerHTML

FF:支持textContent

(8) 是否可用id代替HTML元素

IE:能夠用id來代替HTML元素

FF:不能夠

這裏只列出了常見的,還有很多,更多的介紹能夠參看JavaScript在IE瀏覽器和Firefox瀏覽器中的差別總結

5,規避javascript多人開發函數重名問題

(1) 能夠開發前規定命名規範,根據不一樣開發人員開發的功能在函數前加前綴

(2) 將每一個開發人員的函數封裝到類中,調用的時候就調用類的函數,即便函數重名只要類名不重複就ok

6,javascript面向對象中繼承實現

javascript面向對象中的繼承實現通常都使用到了構造函數和Prototype原型鏈,簡單的代碼以下:

function Animal(name) {

   this.name = name;

}

 

Animal.prototype.getName = function() {alert(this.name)}

function Dog() {};

Dog.prototype = new Animal("Buddy");

Dog.prototype.constructor = Dog;

var dog = new Dog();

7,FF下面實現outerHTML

FF不支持outerHTML,要實現outerHTML還須要特殊處理

思路以下:

在頁面中添加一個新的元素A,克隆一份須要獲取outerHTML的元素,將這個元素append到新的A中,而後獲取A的innerHTML就能夠了。

 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 

<html xmlns="http://www.w3.org/1999/xhtml"> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

<title>獲取outerHMTL</title> 

<style> 

div{ background:#0000FF;width:100px;height:100px;}  

span{ background:#00FF00;width:100px;height:100px;}  

p{ background:#FF0000;width:100px;height:100px;}  

</style> 

</head> 

<body> 

<div id="a"><span>SPAN</span>DIV</div> 

<span>SPAN</span>

<p>P</p> 

<script type="text/javascript">

function getOuterHTML(id){

 var el = document.getElementById(id);

 var newNode = document.createElement("div");

 document.appendChild(newNode);

 var clone = el.cloneNode(true);

 newNode.appendChild(clone);

 alert(newNode.innerHTML);

 document.removeChild(newNode);

}

getOuterHTML("a");

</script>

</body> 

</html>

8,編寫一個方法 求一個字符串的字節長度

假設:

一個英文字符佔用一個字節,一箇中文字符佔用兩個字節

function GetBytes(str){

    var len = str.length;

    var bytes = len;

    for(var i=0; i<len; i++){

        if (str.charCodeAt(i) > 255) bytes++;

    }

    return bytes;

}

alert(GetBytes("你好,as"));

9,編寫一個方法 去掉一個數組的重複元素

var arr = [1 ,1 ,2, 3, 3, 2, 1];

Array.prototype.unique = function(){

    var ret = [];

    var o = {};

    var len = this.length;

    for (var i=0; i<len; i++){

        var v = this[i];

        if (!o[v]){

            o[v] = 1;

            ret.push(v);

        }

    }

    return ret;

};

alert(arr.unique());

10,寫出3個使用this的典型應用

(1)在html元素事件屬性中使用,如

<input type=」button」 onclick=」showInfo(this);」 value=」點擊一下」/>

(2)構造函數

function Animal(name, color) {

   this.name = name;

   this.color = color;

}

(3)

<input type="button" id="text" value="點擊一下" />

<script type="text/javascript">

var btn = document.getElementById("text");

btn.onclick = function() {

alert(this.value); //此處的this是按鈕元素

}

</script>

(4)CSS expression表達式中使用this關鍵字

<table width="100px" height="100px">

  <tr>

    <td>

    <div style="width:expression(this.parentNode.width);">div element</div>

    </td>

  </tr>

</table>

12,如何顯示/隱藏一個DOM元素?

el.style.display = "";//顯示  el.style.visibility= "visible ";

el.style.display = "none";//隱藏   el.style.visibility= "hidden ";

el是要操做的DOM元素

區別:visibility設置爲 hidden 時,元素依然佔有原來的位置

13,JavaScript中如何檢測一個變量是一個String類型?請寫出函數實現

String類型有兩種生成方式:

(1)Var str = 「hello world」;

(2)Var str2 = new String(「hello world」);

function IsString(str){

    return (typeof str == "string" || str.constructor == String);

}

var str = "";

alert(IsString(1)); //false

alert(IsString(str)); // true

alert(IsString(new String(str))); // true

14,網頁中實現一個計算當年還剩多少時間的倒數計時程序,要求網頁上實時動態顯示「××年還剩××天××時××分××秒」

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

   <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

   <title>倒計時</title>

</head>

<body>

<input type="text" value="" id="input" size="1000"/>

<script type="text/javascript">

   function counter() {

      var date = new Date();

      var year = date.getFullYear();

      var date2 = new Date(year, 12, 31, 23, 59, 59);

      var time = (date2 - date)/1000;

      var day =Math.floor(time/(24*60*60))

      var hour = Math.floor(time%(24*60*60)/(60*60))

      var minute = Math.floor(time%(24*60*60)%(60*60)/60);

      var second = Math.floor(time%(24*60*60)%(60*60)%60);

      var str = year + "年還剩"+day+"天"+hour+"時"+minute+"分"+second+"秒";

      document.getElementById("input").value = str;

   }

   window.setInterval("counter()", 1000);

</script>

</body>

</html>

15,補充代碼,鼠標單擊Button1後將Button1移動到Button2的後面<div> <input type=」button」 id =」button1″ value=」1″ onclick=」???」> <input type=」button」 id =」button2″ value=」2″ /」> </div>

<div>

   <input type="button" id ="button1" value="1" onclick="moveBtn(this);">

   <input type="button" id ="button2" value="2" />

</div>

<script type="text/javascript">

function moveBtn(obj) {

   var clone = obj.cloneNode(true);

   var parent = obj.parentNode;

   parent.appendChild(clone);

   parent.removeChild(obj);

}

</script>

16,JavaScript有哪幾種數據類型

簡單:Number,Boolean,String,Null,Undefined

複合:Object,Array,Function

17,下面css標籤在JavaScript中調用應如何拼寫,border-left-color,-moz-viewport

borderLeftColor

mozViewport

18,JavaScript中如何對一個對象進行深度clone

function cloneObject(o) {

    if(!o || 'object' !== typeof o) {

        return o;

    }

    var c = 'function' === typeof o.pop ? [] : {};

    var p, v;

    for(p in o) {

        if(o.hasOwnProperty(p)) {

            v = o[p];

            if(v && 'object' === typeof v) {

                c[p] = Ext.ux.clone(v);

            }

            else {

                c[p] = v;

            }

        }

    }

    return c;

};

19,如何控制alert中的換行

\n alert(「p\np」);

20,請實現,鼠標點擊頁面中的任意標籤,alert該標籤的名稱.(注意兼容性)

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 

<html xmlns="http://www.w3.org/1999/xhtml"> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

<title>鼠標點擊頁面中的任意標籤,alert該標籤的名稱</title> 

<style> 

div{ background:#0000FF;width:100px;height:100px;}  

span{ background:#00FF00;width:100px;height:100px;}  

p{ background:#FF0000;width:100px;height:100px;}  

</style> 

<script type="text/javascript">

document.onclick = function(evt){

 var e = window.event || evt;

 var tag = e["target"] || e["srcElement"];

 alert(tag.tagName);

};

</script>

</head> 

<body> 

<div id="div"><span>SPAN</span>DIV</div> 

<span>SPAN</span>

<p>P</p> 

</body> 

</html> 

21,請編寫一個JavaScript函數 parseQueryString,它的用途是把URL參數解析爲一個對象,如:

var url = 「http://witmax.cn/index.php?key0=0&key1=1&key2=2″;

 

function parseQueryString(url){

   var params = {};

   var arr = url.split("?");

   if (arr.length <= 1)

      return params;

   arr = arr[1].split("&");

   for(var i=0, l=arr.length; i<l; i++){

      var a = arr[i].split("=");

      params[a[0]] = a[1];

   }

   return params;

}

 

var url = "http://witmax.cn/index.php?key0=0&key1=1&key2=2";

var ps = parseQueryString(url);

alert(ps["key1"]);

22,ajax是什麼? ajax的交互模型? 同步和異步的區別? 如何解決跨域問題?

Ajax是多種技術組合起來的一種瀏覽器和服務器交互技術,基本思想是容許一個互聯網瀏覽器向一個遠程頁面/服務作異步的http調用,而且用收到的數據來更新一個當前web頁面而沒必要刷新整個頁面。該技術可以改進客戶端的體驗。包含的技術:

XHTML:對應W3C的XHTML規範,目前是XHTML1.0。

CSS:對應W3C的CSS規範,目前是CSS2.0

DOM:這裏的DOM主要是指HTML DOM,XML DOM包括在下面的XML中

JavaScript:對應於ECMA的ECMAScript規範

XML:對應W3C的XML DOM、XSLT、XPath等等規範

XMLHttpRequest:對應WhatWG的Web Applications1.0規範(http://whatwg.org/specs/web-apps/current-work/

AJAX交互模型

 

同步:腳本會停留並等待服務器發送回覆而後再繼續

異步:腳本容許頁面繼續其進程並處理可能的回覆

跨域問題簡單的理解就是由於JS同源策略的限制,a.com域名下的JS沒法操做b.com或c.a.com下的對象,具體場景以下:

 

PS:(1)若是是端口或者協議形成的跨域問題前端是無能爲力的

(2) 在跨域問題上,域僅僅經過URL的首部來識別而不會嘗試判斷相同的IP地址對應的域或者兩個域是否對應一個IP

前端對於跨域的解決辦法:

(1) document.domain+iframe

(2) 動態建立script標籤

23,什麼是閉包?下面這個ul,如何點擊每一列的時候alert其index?

<ul id=」test」>

<li>這是第一條</li>

<li>這是第二條</li>

<li>這是第三條</li>

</ul>

內部函數被定義它的函數的外部區域調用的時候就產生了閉包。

(function A() {

   var index = 0;

   var ul = document.getElementById("test");

   var obj = {};

   for (var i = 0, l = ul.childNodes.length; i < l; i++) {

      if (ul.childNodes[i].nodeName.toLowerCase() == "li") {

         var li = ul.childNodes[i];

         li.onclick = function() {

            index++;

            alert(index);

         }

      }

   }

})();

24,請給出異步加載js方案,很多於兩種

默認狀況javascript是同步加載的,也就是javascript的加載時阻塞的,後面的元素要等待javascript加載完畢後才能進行再加載,對於一些意義不是很大的javascript,若是放在頁頭會致使加載很慢的話,是會嚴重影響用戶體驗的。

異步加載方式:

(1) defer,只支持IE

(2) async:

(3) 建立script,插入到DOM中,加載完畢後callBack,見代碼:

function loadScript(url, callback){

   var script = document.createElement("script")

   script.type = "text/javascript";

   if (script.readyState){ //IE

      script.onreadystatechange = function(){

         if (script.readyState == "loaded" ||

            script.readyState == "complete"){

            script.onreadystatechange = null;

            callback();

         }

      };

   } else { //Others: Firefox, Safari, Chrome, and Opera

      script.onload = function(){

          callback();

      };

   }

   script.src = url;

   document.body.appendChild(script);

}

25,請設計一套方案,用於確保頁面中JS加載徹底。

var n = document.createElement("script");

n.type = "text/javascript";

//以上省略部分代碼

//ie支持script的readystatechange屬性(IE support the readystatechange event for script and css nodes)

if(ua.ie){

   n.onreadystatechange = function(){

       var rs = this.readyState;

       if('loaded' === rs || 'complete'===rs){

           n.onreadystatechange = null;

           f(id,url); //回調函數

       }

};

//省略部分代碼

//safari 3.x supports the load event for script nodes(DOM2)

   n.addEventListener('load',function(){

       f(id,url);

   });

//firefox and opera support onload(but not dom2 in ff) handlers for

//script nodes. opera, but no ff, support the onload event for link

//nodes.

}else{

   n.onload = function(){

       f(id,url);

   };

}

26,js中如何定義class,如何擴展prototype?

Ele.className = 「***」; //***在css中定義,形式以下:.*** {…}

A.prototype.B = C;

A是某個構造函數的名字

B是這個構造函數的屬性

C是想要定義的屬性的值

27,如何添加html元素的事件,有幾種方法.

(1) 爲HTML元素的事件屬性賦值

(2) 在JS中使用ele.on*** = function() {…}

(3) 使用DOM2的添加事件的方法 addEventListener或attachEvent

28,documen.write和 innerHTML的區別

document.write只能重繪整個頁面

innerHTML能夠重繪頁面的一部分

29,多瀏覽器檢測經過什麼?

(1) navigator.userAgent

(2) 不一樣瀏覽器的特性,如addEventListener

30,js的基礎對象有那些, window和document的經常使用的方法和屬性列出來

String,Number,Boolean

Window:

方法:setInterval,setTimeout,clearInterval,clearTimeout,alert,confirm,open

屬性:name,parent,screenLeft,screenTop,self,top,status

Document

方法:createElement,execCommand,getElementById,getElementsByName,getElementsByTagName,write,writeln

屬性:cookie,doctype,domain,documentElement,readyState,URL,

31,前端開發的優化問題

(1) 減小http請求次數:css spirit,data uri

(2) JS,CSS源碼壓縮

(3) 前端模板 JS+數據,減小因爲HTML標籤致使的帶寬浪費,前端用變量保存AJAX請求結果,每次操做本地變量,不用請求,減小請求次數

(4) 用innerHTML代替DOM操做,減小DOM操做次數,優化javascript性能

(5) 用setTimeout來避免頁面失去響應

(6) 用hash-table來優化查找

(7) 當須要設置的樣式不少時設置className而不是直接操做style

(8) 少用全局變量

(9) 緩存DOM節點查找的結果

(10) 避免使用CSS Expression

(11) 圖片預載

(12) 避免在頁面的主體佈局中使用table,table要等其中的內容徹底下載以後纔會顯示出來,顯示比div+css佈局慢

32,如何控制網頁在網絡傳輸過程當中的數據量

啓用GZIP壓縮

保持良好的編程習慣,避免重複的CSS,JavaScript代碼,多餘的HTML標籤和屬性

33,Flash、Ajax各自的優缺點,在使用中如何取捨?

Ajax的優點

(1) 可搜索型

(2) 開放性

(3) 費用

(4) 易用性

(5) 易於開發

Flash的優點

(1) 多媒體處理

(2) 兼容性

(3) 矢量圖形 比SVG,Canvas優點大不少

(4) 客戶端資源調度,好比麥克風,攝像頭

例子1:

<html>
<head>
<script Language="JavaScript">
var msg="這是一個跑馬燈效果的JavaScript文檔";
var interval = 100;
var spacelen = 120;
var space10=" ";
var seq=0;
function Scroll() { 
len = msg.length;
window.status = msg.substring(0, seq+1);
seq++;
if ( seq >= len ) { 
seq = spacelen; 
window.setTimeout("Scroll2();", interval );
}
else

window.setTimeout("Scroll();", interval );

function Scroll2() { 
var out="";
for (i=1; i<=spacelen/space10.length; i++) out += 
space10;
out = out + msg;
len=out.length;
window.status=out.substring(seq, len);
seq++;
if ( seq >= len ) { seq = 0; };
window.setTimeout("Scroll2();", interval );

Scroll();
</script>
<body>
</body>
</html>

例子2:

<HTML>
<HEAD>
<script Language="JavaScript">
<!--
function loadform(){
alert("這是一個自動裝載例子!");
}
function unloadform(){
alert("這是一個卸載例子!");
}
//-->
</Script>
</HEAD>
<BODY OnLoad="loadform()" OnUnload="unloadform()">
<a href="test.htm">調用</a>
</BODY>
</HTML>

編程篇

編寫一個方法 求一個字符串的字節長度

new function(s){

if(!arguments.length||!s) return null;

     if(""==s) return 0;

     var l=0;

  for(var i=0;i<s.length;i++){

     if(s.charCodeAt(i)>255) l+=2; else l++;

     }

      alert(l);

}("hello world!");

 

如何控制alert中的換行

alert("hello\nworld");

 

解釋document.getElementById("ElementID").style.fontSize="1.5em"

設置id爲ElementID的元素的字體大小爲1.5個相對單位

Em爲相對長度單位。相對於當前對象內文本的字體尺寸。

如當前對行內文本的字體尺寸未被人爲設置,則相對於瀏覽器的默認字體尺寸。

1em=16px

 

按照格式 xxxx年xx月xx日xx時xx分xx秒動態顯示時間 要求不足10的補0

<script type="text/javascript" language="javascript">

function tick(){

        var d=new Date();

        var t=function(a){return a<10?"0"+a:a;}

        Clock.innerHTML=d.getFullYear()+"年"+t(d.getMonth()+1)+"月"+t(d.getDate())+"日"+t(d.getHours())+"時"

        +t(d.getMinutes())+"分"+t(d.getSeconds())+"秒";

        window.setTimeout("tick()",1000);

   }

window.onload=tick;

</script>

 

<body>

<div id="Clock"></div>

</body>

 

編寫一個方法 去掉一個數組的重複元素

Array.prototype.strip=function(){

        if(this.length<2) return [this[0]]||[];

        var arr=[];

        for(var i=0;i<this.length;i++){

            arr.push(this.splice(i--,1));//將本數組中第一個元素取出放入到數組arr中 

            for(var j=0;j<this.length;j++){

                if(this[j]==arr[arr.length-1]){

                    this.splice(j--,1);//刪除本數組中與數組arr中最後一個元素相同的元素

                }

            }

        }

        return arr;

    }

 

    var arr=["abc",85,"abc",85,8,8,1,2,5,4,7,8];

alert(arr.strip());

 

說出3條以上ff和ie的腳本兼容問題

IE有children,FF沒有;

IE有parentElement,FF沒有;

IE有 innerText,outerText,outerHTML,FF沒有;

IE有數據島,FF沒有;

FF有

HTMLElement,HTMLDivElement,XMLDocument,DocumentFragment,Node,Event,Element 等等,IE沒有;

IE跟FF建立HttpRequest實例的方法不同

 

DIV中border、margin和padding的區別和用法

邊框屬性(border)用來設定一個元素的邊線

外邊距屬性(margin)是用來設置一個元素所佔空間的邊緣到相鄰元素之間的距離

內邊距屬性(padding)是用來設置元素內容到元素邊界的距離

 

爲Array寫一個indexof方法

Array.prototype.indexOf = function(e){

        for(var i=0,j; j=this[i]; i++){

            if(j==e){return i;}

        }

        return -1;

    }

    

    Array.prototype.lastIndexOf = function(e){

        for(var i=this.length-1,j; j=this[i]; i--){

            if(j==e){return i;}

        }

        return -1;

    }

    

    var arr=[1,2,3,4,5];

    alert(arr.indexOf(5));

 

克隆

淺複製(影子克隆):只複製對象的基本類型,對象類型,仍屬於原來的引用

深複製(深度克隆):不緊複製對象的基本類,同時也複製原對象中的對象.就是說徹底是新對象產生的

 

Object.prototype.Clone = function(){

     var objClone;

     if( this.constructor == Object )

objClone = new this.constructor();

     else

objClone = new this.constructor(this.valueOf());

     for ( var key in this ){

         if ( objClone[key] != this[key] ){

             if ( typeof(this[key]) == 'object' ){

                 objClone[key] = this[key].Clone();

             }else{

                 objClone[key] = this[key];

             }

         }

     }

     objClone.toString = this.toString;

     objClone.valueOf = this.valueOf;

     return objClone;

  }

 

兼容 IE 和 FF 的換行 CSS 推薦樣式

word-wrap:break-word; overflow:hidden;

 

word-wrap是控制換行的。使用break-word時,是將強制換行。中文沒有任何問題,英文語句也沒問題。可是對於長串的英文,就不起做用。

 

word-break是控制是否斷詞的。

normal是默認狀況,英文單詞不被拆開。

break-all,是斷開單詞。在單詞到邊界時,下個字母自動到下一行。主要解決了長串英文的問題。

keep-all,是指Chinese, Japanese, and Korean不斷詞。即只用此時,不用word-wrap,中文就不會換行了。(英文語句正常。)

 

手型Cursor的兼容IE和FF寫法

cursor:pointer

 

<img>元素的alt和title有什麼異同?

alt做爲圖片的替代文字出現,title是圖片的解釋文字

 

圖片存在

只有alt 圖片的解釋文字

只有title 圖片的解釋文字

二者都有 圖片的解釋文字

二者都沒有 圖片既沒有替代文字,也沒有解釋文字

 

圖片不存在

只有alt 圖片既有替代文字,又有解釋文字

只有title 圖片沒有替代文字,只有解釋文字

二者都有 圖片既有替代文字,又有解釋文字

二者都沒有 圖片既沒有替代文字,也沒有解釋文字

 

固然不一樣的瀏覽器處理方式也會不同

 

border-color-left、marin-left、-moz-viewport改寫成JavaScript格式

border-color-left:borderLeftColor

marin-left:marinLeft

-moz-viewport:MozViewport

 

用css、html編寫一個兩列布局的網頁,要求右側寬度爲200px,左側自動擴展。

CSS:

#right{

float:right;

width:200px;

}

#left{

marin-right:200px;

}

HTML:

<body>

<div id=」right」>…</div>

<div id=」left」>…</div>

</body>

 

Linux題目:批量刪除當前目錄下後綴名爲.c的文件,如a.c、b.c

rm *.c

 

如何提升網頁的運行速度

內容與形式分離,模塊化開發,優化CSS

減小頁面文檔大小

儘可能減小圖片的使用或注意圖片的大小,優化圖片:格式、質量、圖片長寬標誌

減小響應的次數,用Ajax

網址後面加一個「/」

相關文章
相關標籤/搜索