這一定會是一個可愛的工具,節省時間不說,而且可以清晰的記錄和比較數據.下 " /> 美女很黄很黄是免费的·无遮挡网站 ,jdav视频在线观看,成人看片黄a免费

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

在一個瀏覽器里呈現所有瀏覽器測試結果的前端測試工具的思路

作為一個標準的絕頂的懶人,我想做一個測試工具,可以同時把所有瀏覽器的測試結果都顯示在一個瀏覽器窗口里,并且列成清晰的表格,便于比較.

這一定會是一個可愛的工具,節省時間不說,而且可以清晰的記錄和比較數據.下面說一下我的思路.(之后我將使用這個工具測試一個js的兼容性問題,敬請關注)

本工具已經制作完成,但是不具通用性,需要和后臺配合使用,需要和數據庫交互,而且后臺交互的性能不太好,普通的電腦無法承受(我的3GHZ的cpu,2G內存都不能直接打開多個瀏覽器窗口,可能是我數據庫的操作過于頻繁).雖然放在公共服務器上速度可以接受,但是不能拿出來給大家測試,因為多個人運行,再好的服務器也受不了.

工具是js+php+mysql制作的,并不是有的人想象的把多個瀏覽器引擎整合到一個軟件里,我可沒那水平.

使用的時候,只需要在js里寫好測試數據和測試方法,傳到一個測試實例里,然后在所有瀏覽器里打開一次這個窗口,js會統計數據,然后把數據存儲到后臺,之后js通過ajax獲取所有的數據,將其解析成表格顯示在網頁中.最后結果是如果你的電腦夠強,所有的瀏覽器里的網頁都會顯示一個列表,里面有所有瀏覽器的測試數據,如下:

之后就可以比較結果了.是不是很方便呢
原理:
首先將此功能抽象成一個組件,組件接受三個參數,一個是輸入對象組,二是測試方法,三是組件配置參數.
在之后的組件初始化階段,組件將遍歷輸入對象組中的所有對象,將對象傳給測試方法,測試方法返回一個測試數據,組件將測試結果記錄在一個對象中.
復制代碼 代碼如下:
/**
* 這是一個測試對象在不同瀏覽器中屬性的對象,可以同時在任何瀏覽器中測試,需要和后臺腳本交互
* 請設置好輸入數據和輸出數據后,在要測試的瀏覽器中打開頁面,結果將附加到列表中.
*
* @param {array} testObject 待測試的對象列表,每個對象都必須有一個唯一的標示做主鍵,而且有一個描述,
* testObject的格式如下{"in1":{obj:**,des:"dd"},"in2":{obj:**,des:"dd"}}
* @param {function} testMethod 測試的方法,程序會向此方法傳入兩個參數,一個是對象索引一個是對象.同時在此方法里可以用this引用test實例,此方法必須返回一個字符串,表示執行結果
* @param {json} config 配置參數
*/
(function(){
var CrossBrowserTest=function(testObjects,testMethod,config){

這個組件對對象參數格式和組件內的數據存儲器的格式,以及向后臺發送字符串的格式,后臺返回數據的格式有著嚴格規定:
其中:testObject的格式如下{"in1":{obj:**,des:"dd"},"in2":{obj:**,des:"dd"}}
組件內的數據存儲器的格式如下(this.data):{“in1”:{des:”描述",data{“ie6”:{outDes:"ie6里的輸出結果"},”ie7”:{outDes:"ie7里的輸出結果"}}},"in2”:…}
在發送數據的時候,用一個函數將json轉換成字符串格式,這個函數如下:
復制代碼 代碼如下:
function obj2str(o){
var r = [];
if(typeof o =="string") return "/""+o+"/"";
if(typeof o == "object"){
if(!o.sort){
r[0]="{"
for(var i in o){
r[r.length]="/""+i+"/"";
r[r.length]=":";
r[r.length]=obj2str(o[i]);
r[r.length]=",";
}
r[r.length-1]="}"
}else{
r[0]="["
for(var i =0;i<o.length;i++){
r[r.length]=obj2str(o[i]);
r[r.length]=",";
}
r[r.length-1]="]"
}
return r.join("");
}
return o.toString();
}

在后臺,php會把這個json字符串通過json_decode函數轉換成一個php的數組,之后存到數據庫里.
而從數據庫里取數據的時候,php從數據庫里取出數據,轉換成數組格式,然后用json_encode函數轉換成json字符串,傳到前臺,前臺用eval執行得到數據.
在后臺,對json數據進行了分解,分解成了一條條的數據,然后存到了數據庫里,這里數據庫讀取頻繁,造成性能下降.
數據庫有6個字段,分別為:主鍵,對象主鍵(區分不同的對象),瀏覽器類型(相同的對象里有不同瀏覽器的測試結果),對象的描述,測試的結果,時間.
瀏覽器的類型測試使用了下述的方法:
復制代碼 代碼如下:
M.getBrowser=function(){
return {
//此函數判斷瀏覽器類型,為了簡便,返回一個數字表示,
//1.ie6;2.ie7; 3.ie8;4,Firefox;5.chrome;6.Opera;7.Safari;0.無法檢測的瀏覽器
//其他瀏覽器可以自行添加
whichOS:function(){
var useragent=navigator.userAgent.toLowerCase();
return (/MSIE 6/i.test(useragent)==true&&1)||
(/MSIE 7/i.test(useragent)==true&&2)||(/MSIE 8/i.test(useragent)==true&&3)||
(/Firefox/i.test(useragent)==true&&4)||
(/Chrome/i.test(useragent)==true&&5)||
(/Opera/i.test(useragent)==true&&6)||
(/Safari/i.test(useragent)==true&&7)||0
},
nowOsString:function(){
var useragent=navigator.userAgent.toLowerCase();
return (/MSIE 6/i.test(useragent)==true&&"ie6")||
(/MSIE 7/i.test(useragent)==true&&"ie7")||(/MSIE 8/i.test(useragent)==true&&"ie8")||
(/Firefox/i.test(useragent)==true&&"Firefox")||
(/Chrome/i.test(useragent)==true&&"Chrome")||
(/Opera/i.test(useragent)==true&&"Opera")||
(/Safari/i.test(useragent)==true&&"Safari")||"sorry,我不認識你的瀏覽器!"
}
}
}()

數據是用對象主鍵和瀏覽器類型共同區分的(可以獲取唯一的數據)
對象初始化完成后,就開始處理數據了,首先在本瀏覽器里執行一次測試,將測試數據放入一個臨時對象里,然后將這個臨時對象通過ajax發送到后臺,后臺把這條數據存到數據庫(如果已經存在就不存儲了)
然后設置一個定時器,定時到后臺取數據,這個取到的數據是后臺數據庫里存儲的,可能包括了多個的瀏覽器的數據,取到數據后,啟動dom構建函數,和渲染函數,更新網頁的內容.
基本原理就是這樣,這樣說真是抽象的很,但是很抱歉,這個東西沒法拿出來跟大家分享,不是我不想分享,是實在是有困難.不過如果你感興趣可以下載源代碼,將源代碼里的sql導入到一個mysql表里,然后在php文件里配置下,修改下,我這個封裝的不是很好,因為考慮到這個東西的重用性也不用太好了.沒時間搞別的了.
測試代碼打包下載

JavaScript技術在一個瀏覽器里呈現所有瀏覽器測試結果的前端測試工具的思路,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美日韩一区二区亚洲 | 久久久久中文字幕 | 色天使色护士 在线视频观看 | 成人精品一区二区激情 | 国产 麻豆 欧美亚洲综合久久 | 国产精品露脸国语对白手机视频 | 91青青草视频在线观看 | 开心久久激情 | 久久久国产精品va麻豆 | 日韩精品福利视频一区二区三区 | 国产精品欧美亚洲韩国日本 | 国产欧美视频综合二区 | 欧美一级一一特黄 | 精品123区 | 一区二区三区四区国产精品 | 精品国产福利久久久 | 精品国产第一国产综合精品gif | 色婷五月综激情亚洲综合 | 亚洲欧美国产18 | 色噜噜国产在线91蝌蚪 | 亚洲精品免费网站 | 91在线欧美精品观看 | 亚洲天堂久久精品 | 欧美人的性视频 | 亚洲第一视频在线播放 | 欧美日韩亚洲国产一区二区三区 | 高清国产欧美一v精品 | 一区二区高清在线观看 | 国产免费久久精品99久久 | 色成年激情久久综合 | 成人最新午夜免费视频 | 欧美色黄视频 | 欧美日本视频在线观看 | 在线黄观看 | 亚洲黄视频 | 国产欧美亚洲三区久在线观看 | 性欧美xxxx乳高跟 | 午夜视频国语 | 嫩草免费| 国产成人亚洲综合欧美一部 | 激情综合激情五月 |