您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關AJAX有哪些常見面試問題,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
1.工作當中會和后臺交互嗎? 那你能說說封裝好的 ajax里的幾個參數嗎 ?
url: 發送請求的地址。
type: 請求方式(post或get)默認為get。
async: 同步異步請求,默認true所有請求均為異步請求。
timeout : 超時時間設置,單位毫秒
data:要求為Object或String類型的參數,發送到服務器的數據
cache:默認為true(當dataType為script時,默認為false), 設置為false將不會從瀏覽器緩存中加載請求信息。
dataType: 預期服務器返回的數據類型。
可用的類型如下:
xml:返回XML文檔,可用JQuery處理。
html:返回純文本HTML信息;包含的script標簽會在插入DOM時執行。
script:返回純文本JavaScript代碼。不會自動緩存結果。
json:返回JSON數據。
jsonp:JSONP格式。使用JSONP形式調用函數時,例如myurl?callback=?,JQuery將自動替換后一個“?”為正確的函數名,以執行回調函數。
text:返回純文本字符串。
success:請求成功后調用的回調函數,有兩個參數。
(1) 由服務器返回,并根據dataType參數進行處理后的數據。
(2) 描述狀態的字符串。
error:要求為Function類型的參數,請求失敗時被調用的函數。該函數有3個參數
(1) XMLHttpRequest對象
(2) 錯誤信息
(3) 捕獲的錯誤對象(可選)
complete :function(XMLHttpRequest,status){ //請求完成后最終執行參數
2.json數據 如果怎么處理 他的格式 你以前工作中有沒有固定格式 如果我發送一個請求 刪除數據里的一條數據 我怎么知道刪除成功了 或者說 刪除后 會在哪里顯示
JSON.parse() 轉換為JSON對象,根據數據進行解析,放到頁面中。
格式:{} 與 [] 結合拼接的JSON串
發送請求刪除數據,后臺會返回處理的結果,前臺根據返回的結果判斷是否成功,然后處理頁面元素。
3.有沒有遇到過這種情況 在ie瀏覽器中 后臺圖片數據已經改變 但是客戶端沒有發生改變 該怎么處理? 他提示說瀏覽器的緩存
JQuery.ajax() 方法,設置cache為false,就不會從瀏覽器緩存中加載請求,
或者利用post方法,請求數據,不會緩存,每次都是重新請求數據
4.選項卡的實現思路
鼠標懸浮時間,調用方法,傳入this,對所有的選項卡內容部分隱藏操作,對this的進行顯示操作,控制display
5.級聯 的實現思路
一般地區數據都是利用二維數組存儲,從后臺獲取到以后存儲起來,根據第一個下拉框的選項,找到對應的二維數組數據,循環new Option() add進下拉框
6. 輪播圖的實現思路
第一種:
把圖片名稱按順序取好名字,利用定時器,每隔多少秒,更換圖片的路徑
第二種:
利用無縫滾動的技術,把圖片都放入頁面中,定時器進行scroll滾動,判斷滾動距離取余(%) 圖片寬度等于0,暫停定時器,多少秒后再開啟定時器。
7.說說你理解中的bootstrap
Bootstrap是基于HTML5和CSS3開發的,它在jQuery的基礎上進行了更為個性化和人性化的完善,只需要給標簽起上響應的Class名稱,就可以形成一套Bootstrap自己獨有的網站風格,并兼容大部分jQuery插件。
8.angularjs和JQ的區別
JQ 先獲取再使用。
Angularjs 直接使用
9.JQmobile和JQ的區別
jQuery Mobile 是創建移動 web 應用程序的框架。jQuery Mobile 適用于所有流行的智能手機和平板電腦。jQuery Mobile 使用 HTML5 和 CSS3 通過盡可能少的腳本對頁面進行布局
(1) jQuery是一個js庫,主要提供的功能是選擇器,屬性修改和事件綁定等等。
(2) jQuery UI則是在jQuery的基礎上,利用jQuery的擴展性,設計的插件。提供了一些常用的界面元素,諸如對話框、拖動行為、改變大小行為等等。
(3) jQuery本身注重于后臺,沒有漂亮的界面,而jQuery UI則補充了前者的不足,他提供了華麗的展示界面,使人更容易接受。既有強大的后臺,又有華麗的前臺。jQuery UI是jQuery插件,只不過專指由jQuery官方維護的UI方向的插件。
10.你工作當中用過那些庫?
11.(1)冒泡排序,60秒倒計時,(2)頁面加載更多li時怎么處理后臺反回的json數據
1.雙重循環,從第一位開始判斷與后面每一位的大小,如果符合條件利用下面的原理換位置
c = a;
a = b;
b = c;
2.利用JSON.parse() 獲得相應的JSON對象,循環添加li,數據放進去。
12.全選的實現思路
點擊全選復選框時,判斷checked是true還是false,是true證明全都選中,獲取到下面所有的對應的復選框,把checked改成true,否則改成false。
13.有一個輸入框,只允許輸入數字或字母,如果輸入不合法則將輸入框的邊框變為紅色,寫代碼
var reg =/^[a-zA-Z0-9]+$/; if(!reg.text(輸入框取出的value)){ input.style.border= “red”; };
14.有一個數組a=[1,2,3],如果數字a中包含1,則將數組內容復制一遍變為[1,2,3,1,2,3],寫代碼
for(var i = 0;i<a.length;i++){ if(a[i] ==1){ a.concat(a); break; } }15.寫一個函數,用于生產隨機密碼,傳入的參數為密碼的長度,返回生產的隨機密碼,要求生成的隨機密碼必須含有大寫字母、小寫字母和數字
var padArr = ["a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z","A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z","0","1","2","3","4","5","6","7","8","9"];var padStr = "";function asd(length){ for(var i = 0 ; i<length;i++){ padStr += padArr[Math.floor(Math.random()*padArr.length)]; } }
16.點擊按鈕向后臺發起請求,將返回的數據直接輸出,如果3秒內沒有獲得返回的數據則顯示“請求超時,請重新提交”,寫代碼
varajaxTimeoutTest = $.ajax({ url:'', //請求的URL timeout : 1000, //超時時間設置,單位毫秒 type : 'get', //請求方式,get或post data :{}, //請求所傳參數,json格式 dataType:'json',//返回的數據格式 success:function(data){ //請求成功的回調函數 alert("成功"); }, complete : function(XMLHttpRequest,status){ //請求完成后最終執行參數 if(status=='timeout'){//超時,status還有success,error等值的情況 ajaxTimeoutTest.abort();//終止請求 alert("超時"); } } });
17.ajax的四部:
var xmlhttp = new XMLHttpRequest(); xmlhttp.open("post||get","URL",true||false); xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded"); xmlhttp.onreadystatechange = callBack; xmlhttp.send(null);
18.ajax接受到的數據類型是什么?
String
JSON串
JSON對象
19.ajax接受到的數據如何處理?
JSON對象直接循環使用
JSON串轉JSON使用
String直接使用
20.哪些地方需要ajax,哪些地方不需要,ajax的優點是什么,缺點是什么?
頁面不進行跳轉刷新的時候,異步處理數據的時候,表單自動補全功能----使用Ajax,
提交后不再使用原頁面,可以進行跳轉刷新的,查詢之類的功能,可以不用Ajax
優點:
<1>.無刷新更新數據。
AJAX最大優點就是能在不刷新整個頁面的前提下與服務器通信維護數據。這使得Web應用程序更為迅捷地響應用戶交互,并避免了在網絡上發送那些沒有改變的信息,減少用戶等待時間,帶來非常好的用戶體驗。
<2>.異步與服務器通信。
AJAX使用異步方式與服務器通信,不需要打斷用戶的操作,具有更加迅速的響應能力。優化了Browser和Server之間的溝通,減少不必要的數據傳輸、時間及降低網絡上數據流量。
<3>.前端和后端負載平衡。
AJAX可以把以前一些服務器負擔的工作轉嫁到客戶端,利用客戶端閑置的能力來處理,減輕服務器和帶寬的負擔,節約空間和寬帶租用成本。并且減輕服務器的負擔,AJAX的原則是“按需取數據”,可以最大程度的減少冗余請求和響應對服務器造成的負擔,提升站點性能。
<4>.基于標準被廣泛支持。
AJAX基于標準化的并被廣泛支持的技術,不需要下載瀏覽器插件或者小程序,但需要客戶允許JavaScript在瀏覽器上執行。隨著Ajax的成熟,一些簡化Ajax使用方法的程序庫也相繼問世。同樣,也出現了另一種輔助程序設計的技術,為那些不支持JavaScript的用戶提供替代功能。
<5>.界面與應用分離。
Ajax使WEB中的界面與應用分離(也可以說是數據與呈現分離),有利于分工合作、減少非技術人員對頁面的修改造成的WEB應用程序錯誤、提高效率、也更加適用于現在的發布系統。
缺點:
<1>.AJAX干掉了Back和History功能,即對瀏覽器機制的破壞。
在動態更新頁面的情況下,用戶無法回到前一個頁面狀態,因為瀏覽器僅能記憶歷史記錄中的靜態頁面。一個被完整讀入的頁面與一個已經被動態修改過的頁面之間的差別非常微妙;用戶通常會希望單擊后退按鈕能夠取消他們的前一次操作,但是在Ajax應用程序中,這將無法實現。
后退按鈕是一個標準的web站點的重要功能,但是它沒法和js進行很好的合作。這是Ajax所帶來的一個比較嚴重的問題,因為用戶往往是希望能夠通過后退來取消前一次操作的。那么對于這個問題有沒有辦法?答案是肯定的,用過Gmail的知道,Gmail下面采用的Ajax技術解決了這個問題,在Gmail下面是可以后退的,但是,它也并不能改變Ajax的機制,它只是采用的一個比較笨但是有效的辦法,即用戶單擊后退按鈕訪問歷史記錄時,通過創建或使用一個隱藏的IFRAME來重現頁面上的變更。(例如,當用戶在Google Maps中單擊后退時,它在一個隱藏的IFRAME中進行搜索,然后將搜索結果反映到Ajax元素上,以便將應用程序狀態恢復到當時的狀態。)
但是,雖然說這個問題是可以解決的,但是它所帶來的開發成本是非常高的,并與Ajax框架所要求的快速開發是相背離的。這是Ajax所帶來的一個非常嚴重的問題。
一個相關的觀點認為,使用動態頁面更新使得用戶難于將某個特定的狀態保存到收藏夾中。該問題的解決方案也已出現,大部分都使用URL片斷標識符(通常被稱為錨點,即URL中#后面的部分)來保持跟蹤,允許用戶回到指定的某個應用程序狀態。(許多瀏覽器允許JavaScript動態更新錨點,這使得Ajax應用程序能夠在更新顯示內容的同時更新錨點。)這些解決方案也同時解決了許多關于不支持后退按鈕的爭論。
<2>.AJAX的安全問題。
AJAX技術給用戶帶來很好的用戶體驗的同時也對IT企業帶來了新的安全威脅,Ajax技術就如同對企業數據建立了一個直接通道。這使得開發者在不經意間會暴露比以前更多的數據和服務器邏輯。Ajax的邏輯可以對客戶端的安全掃描技術隱藏起來,允許黑客從遠端服務器上建立新的攻擊。還有Ajax也難以避免一些已知的安全弱點,諸如跨站點腳步攻擊、SQL注入攻擊和基于Credentials的安全漏洞等等。
<3>.對搜索引擎支持較弱。
對搜索引擎的支持比較弱。如果使用不當,AJAX會增大網絡數據的流量,從而降低整個系統的性能。
<4>.破壞程序的異常處理機制。
至少從目前看來,像Ajax.dll,Ajaxpro.dll這些Ajax框架是會破壞程序的異常機制的。關于這個問題,曾在開發過程中遇到過,但是查了一下網上幾乎沒有相關的介紹。后來做了一次試驗,分別采用Ajax和傳統的form提交的模式來刪除一條數據……給我們的調試帶來了很大的困難。
<5>.違背URL和資源定位的初衷。
例如,我給你一個URL地址,如果采用了Ajax技術,也許你在該URL地址下面看到的和我在這個URL地址下看到的內容是不同的。這個和資源定位的初衷是相背離的。
<6>.AJAX不能很好支持移動設備。
一些手持設備(如手機、PDA等)現在還不能很好的支持Ajax,比如說我們在手機的瀏覽器上打開采用Ajax技術的網站時,它目前是不支持的。
<7>.客戶端過肥,太多客戶端代碼造成開發上的成本。
編寫復雜、容易出錯;冗余代碼比較多(層層包含js文件是AJAX的通病,再加上以往的很多服務端代碼現在放到了客戶端);破壞了Web的原有標準。
21.你對于跨域請求了解多少?
同源策略規定在訪問時如果域名,協議,端口與發起請求的地方不一致時,就屬于跨域請求,
這種時候,需要使用一些跨域請求的技術,
一:
利用JQuery的方法,使用JSONP模式訪問,dataType:‘jsonp’并且再url后傳入callback=?
JQuery會生成隨機回調函數名稱,或者你自己起名字。
后臺會獲取callback的值,連接上() 把數據放入() 中,返回頁面,
相當于調用函數function名(data)。
二:
使用js標簽加載方式
利用script標簽 src寫想要請求的URL,地址后面連接上參數?callback= 函數名
后臺會獲取callback的值,連接上() 把數據放入() 中,返回頁面,
相當于調用函數function名(data)
三:
后臺直接開啟同源策略的訪問限制,設置響應頭信息。
response.setHeader("Access-Control-Allow-Origin","*");
22.如何控制網頁在網絡傳輸中的數據量?
分頁加載,瀑布流,限制每次加載的數據量。(??????不確定)
23.前端常規開發優化策略?
請減少HTTP請求
請正確理解 Repaint 和 Reflow
請減少對DOM的操作
使用JSON格式來進行數據交換
高效使用HTML標簽和CSS樣式
使用CDN加速(內容分發網絡)
將CSS和JS放到外部文件中引用,CSS放頭,JS放尾
精簡CSS和JS文件(壓縮)
壓縮圖片和使用圖片Sprite技術
注意控制Cookie大小和污染
24.為什么異步加載JS文件?加載方式?
平時常用的引入JS方式,是同步模式,又稱阻塞模式,會阻止瀏覽器的后續處理,停止了后續的解析,也就是說,瀏覽器在下載或執行該js代碼塊時,后面的標簽不會被解析。
異步加載(async)JS文件,允許頁面內容異步加載,僅適用于外部腳本。
延遲加載(defer)屬性規定是否對腳本執行進行延遲,直到頁面加載為止。
25.如果對一個js對象進行深度拷貝?
varajaxTimeoutTest = $.ajax({ url:'', //請求的URL timeout : 1000, //超時時間設置,單位毫秒 type : 'get', //請求方式,get或post data :{}, //請求所傳參數,json格式 dataType:'json',//返回的數據格式 success:function(data){ //請求成功的回調函數 alert("成功"); }, complete : function(XMLHttpRequest,status){ //請求完成后最終執行參數 if(status=='timeout'){//超時,status還有success,error等值的情況 ajaxTimeoutTest.abort();//終止請求 alert("超時"); } } });
26.JS中有哪些數據類型?
number boolean string underfind null
object function array
27.ajax交換模型?同步異步的區別?
觸發事件調用函數
創建XMlHttpRequest 對象open連接,send發送后臺服務器
后臺接收前端數據,根據業務需求訪問數據庫進行增刪改查
數據庫返回后臺程序所需要的數據
后臺拿到數據庫數據,進行合理的處理,比如JSON串,返回給前端
前端接收到后臺的響應數據,進行解析,根據業務需求動態操作頁面元素
28.如何添加HTML事件,三種。
1. 直接在html標簽的屬性上添加<p οnclick="alert('p')">p</p> 2. 用dom的on...方法添加document.getElementById('p').onclick = function () {alert('p')}; 3. 用事件監聽addEventListener或attachEvent(IE)添加document.getElementById('p').addEventListener('click', function () {alert('p')}, false);
29.JS面向對象中繼承的實現方式?
簡單繼承:
function A(x){ this.x=x; }
function B(x,y){ this.tmpObj=A; this.tmpObj(x); delete this.tmpObj; this.y=y; }
完美繼承:
function AA(x){ this.x = x;}AA.prototype.xxx = 2;function Obj(){ AA.call(this,22); this.cc = 11; this.constructor = arguments.callee; }Obj.prototype = new AA();var obj = new Obj();
30.編寫一個方法,判斷字符串是否是這樣的組成,第一個必須是字母,最后一個必須是數字。
function checkStr(str){ var diyige =str.subStr(0,1); var dierge =str.subStr(str.length-1,1); var reg = /^[a-zA-Z]$/ if(reg.test(diyige) &&!isNAN(dierge)){ //第一個是字母,最后一個是數字 } }
31.如何隱藏一個DOM元素?
Object.style.dispaly = “none”; || Object.style.visibility = “hidden”;
32.document.write,innerHTML和innertext區別是什么?
document.write只能重繪整個頁面
innerHTML可以重繪頁面的一部分(包含標簽+文字)
innertext可以重繪頁面的一部分(只包含文字)
33.字符串abcdefg把de換成12,b后面接le,寫出JS。
var str = “abcdefg”; str = str.replace(“de”,”12”); str = str.replace(“b”,”b1e”);
或者
var str = “abcdefg”; str = str.split(“de”,”12”); var str1 =str.subString(0,str.indexOf(‘b’)+1); var str2 =str.subString(str.indexOf(‘b’)+1); str = str1+”1e”+str2;
34.判斷每個字符出現的次數:hello,最后顯示: h:1,e:1,l:2,o:1.
var str = “hello”; var o = []; for(var i = 0 ;i<str.length;i++){ if(str.indexOf(str[i]) == i){ o[str[i]] = str.split(str[i]).length-1; } } console.log(o);
35.使用CSS3動畫效果實現一個小球的來回滾動。
36.h6的canvas畫板如何實現會旋轉的地球儀效果?(說出思想)
37.如何使過長的字體自動隱藏?
text-overflow: hidden ;
38.一個H5+C3的鼠標懸停效果?
39.移動端跟PC端的js文件區別?
40.如何處理一些手機端的兼容性?
41.IE瀏覽器兼容性,你了解哪些,簡單舉例子。
addEventListener() || attachEvent()
42.談談你對框架的理解。
對功能進行封裝,使用者直接調用,或對樣式進行預設置,使用者直接起名字
43.如何實現跨域?具體怎么實現?
第一種:
JSONP,利用傳遞方法名的方式,告訴后臺前端方法名是什么,后臺取到后,在名稱后面拼接(),把數據(DATA)放到小括號中,返回前端,相當于返回:方法名(data)到前端后就直接調用這個方法了。
$.get(“ULR?callback=?”,function(data){ console.log(data); })
第二種:
前端正常Ajax訪問,后臺開啟同源策略限制!
“Access-Control-Allow-Origin”,”*”
44.對后臺語言了解幾種,如果了解其中一種,舉例說明一個?
45.與后臺的交互,AJAX只是其中的一小部分,其他的知道嗎?
46.在上一家公司的要上線作品的具體流程是什么?
前后臺項目整合,測試,上線
47.手機端和PC端有什么區別,需要注意哪些方面?
本質上沒有什么太大的區別,需要注意一些瀏覽器的兼容問題。
48.用JQ完整的寫出AJAX與后臺交互的方法。
$.get(“url”,function(data){ }); $.post(“url”,{data},function(data){ }); $.ajax({ url:””, ...... ..... .... });
49.編寫一段jq的方法擴展。
50.ECMAScript6怎么寫class. 為什么會出現class這種東西?
51.如何判斷一個對象是否屬于某個類?
var obj = new String("abc"); alert(obj instanceof String);
52.使用過哪些可視化控件?
53.什么是閉包?
簡單理解成:定義在一個函數內部的函數
閉包本質:將函數內部和函數外部連接起來的一座橋梁
最大用處:
1、可以讀取函數內部變量
2、就是讓這些變量始終保持在內存中,即閉包可以使得它誕生環境一直存在
54.eval可以計算某個字符串,有沒有更好的方式?
55.初始化CSS除了瀏覽器兼容還有什么作用?
關于AJAX有哪些常見面試問題就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。