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
網址後面加一個「/」