欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用JavaScript 實現(xiàn)各種跨域的方法

 更新時間:2013年05月08日 17:59:18   作者:  
本篇文章是對在JavaScript中實現(xiàn)各種跨域方法的介紹。需要的朋友參考下

一、一些概念

①傳統(tǒng)Ajax:交互的數(shù)據(jù)格式——自定義字符串或XML描述;

    跨域——通過服務(wù)器端代理解決。

②如今最優(yōu)方案:使用JSON格式來傳輸數(shù)據(jù),使用JSONP來跨域。

③JSON:一種數(shù)據(jù)交換格式?;诩兾谋尽⒈辉鶭S支持。

      格式:兩種數(shù)據(jù)類型描述符:大括號{ }、方括號[ ]。分隔符逗號、映射符冒號、定義符雙引好。

④JSONP:一種跨域數(shù)據(jù)交互協(xié)議,非官方。

  1、Web頁面調(diào)用js文件,可跨域。擴(kuò)展:但凡有src屬性的標(biāo)簽都具有跨域能力。

  2、跨域服務(wù)器 動態(tài)生成數(shù)據(jù) 并存入js文件(通常json后綴),供客戶端 調(diào)用。

  3、為了便于客戶端使用數(shù)據(jù),形成一個非正式傳輸協(xié)議,稱為JSONP。該協(xié)議重點是允許用戶傳遞一個callback參數(shù)給服務(wù)器,然后服務(wù)器返回數(shù)據(jù)時 將此callback參數(shù)作為函數(shù)名包裹住JSON數(shù)據(jù),使得客戶端可以隨意定制自己的函數(shù)來自動處理返回數(shù)據(jù)。


二、JSONP實現(xiàn)

實例1——客戶端單方面接收:

①客戶端——在客戶端設(shè)置創(chuàng)建一個函數(shù)對象,名稱可為callFunc,用于接收服務(wù)器的js數(shù)據(jù)和對其進(jìn)行處理。
  js數(shù)據(jù)中的核心是:調(diào)用callFunc函數(shù)的同時附帶著參數(shù),此參數(shù)即data對象的值。

復(fù)制代碼 代碼如下:

<script type="text/javascript">
    var callFunc = function(data){
        alert('遠(yuǎn)程js文件傳來的數(shù)據(jù):' + data.result);//data為服務(wù)器端的JSON數(shù)據(jù)對象。
    };
</script>
<script type="text/javascript" src="http://其他域的js文件.com/remote.js"></script>

②服務(wù)器端——直接調(diào)用客戶端js中的函數(shù),并傳入數(shù)據(jù)。
復(fù)制代碼 代碼如下:

callFunc({"result":"value1"});

實例2——客戶端向服務(wù)器傳送 指定函數(shù)名,服務(wù)器端接收該函數(shù)名 并調(diào)用對應(yīng)函數(shù) 將數(shù)據(jù)以參數(shù)形式傳入。
復(fù)制代碼 代碼如下:

<script type="text/javascript">
    // 得到航班信息查詢結(jié)果后的回調(diào)函數(shù)
    var flightHandler = function(data){
        alert('你查詢的航班結(jié)果是:票價 ' + data.price + ' 元,' + '余票 ' + data.tickets + ' 張。');
    };
    // 動態(tài)添加鏈接服務(wù)器js文件的script。
  // 在url地址中傳遞了一個code參數(shù)匹配JSON數(shù)據(jù)中的某個key,callback參數(shù)則告訴服務(wù)器:本地回調(diào)函數(shù)名為callFuncName。
    var url = "http://flightQuery.com/jsonp/flightResult.aspx?code=CA1998&callback=callFuncName";
    var script = document.createElement('script');
    script.setAttribute('src', url);
    // 將script元素在網(wǎng)頁加載時插入head頭部
    document.getElementsByTagName('head')[0].appendChild(script);
</script>

總結(jié):實現(xiàn)的代碼并不復(fù)雜,但在實現(xiàn)Ajax跨域、frameset/iframe跨域等卻是效率頗高的。

相關(guān)文章

  • HTML form表單提交方法案例詳解

    HTML form表單提交方法案例詳解

    這篇文章主要介紹了HTML form表單提交方法案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • Javascript學(xué)習(xí)筆記6 prototype的提出

    Javascript學(xué)習(xí)筆記6 prototype的提出

    所以你還會再說是否用prototype都是一樣的么?其實我以前也是這么理解的,在這次偶然的試驗中看到了這個問題。
    2010-01-01
  • javascript的數(shù)據(jù)類型、字面量、變量介紹

    javascript的數(shù)據(jù)類型、字面量、變量介紹

    javascript的數(shù)據(jù)類型、字面量、變量介紹,學(xué)習(xí)js的朋友可以參考下
    2012-05-05
  • 詳解JavaScript中shift()方法的使用

    詳解JavaScript中shift()方法的使用

    這篇文章主要介紹了詳解JavaScript中shift()方法的使用,是JS入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-06-06
  • JavaScript replace(rgExp,fn)正則替換的用法

    JavaScript replace(rgExp,fn)正則替換的用法

    再看jQuery源碼的時候遇到了replace中參數(shù)為函數(shù)的用法,正好復(fù)習(xí)一下replace正則替換的用法。
    2010-03-03
  • javascript學(xué)習(xí)筆記(三)BOM和DOM詳解

    javascript學(xué)習(xí)筆記(三)BOM和DOM詳解

    本文應(yīng)用了很多實例,來解讀JavaScript中BOM和DOM,DOM是一個使程序和腳本有能力動態(tài)地訪問和更新文檔的內(nèi)容、結(jié)構(gòu)以及樣式的平臺和語言中立的接口。,而BOM定義了JavaScript可以進(jìn)行操作的瀏覽器的各個功能部件的接口。
    2014-09-09
  • javascript之Boolean類型對象

    javascript之Boolean類型對象

    本文主要介紹javascript中的Boolean類型對象,Boolean對象非常簡單,卻非常有用,希望能給大家做一個參考。
    2016-06-06
  • JavaScript的繼承實現(xiàn)小結(jié)

    JavaScript的繼承實現(xiàn)小結(jié)

    JavaScript作為面向?qū)ο蟮娜躅愋驼Z言,繼承也是其非常強(qiáng)大的特性之一。那么如何在JS中實現(xiàn)繼承呢?本文將給大家揭開神秘面紗
    2017-05-05
  • Javascript Objects詳解

    Javascript Objects詳解

    在JavaScript中,對象(Objects)是數(shù)據(jù)(變量),屬性和方法。 幾乎“一切”的JavaScript視為對象。日期,數(shù)組,字符串,函數(shù)的…在JavaScript中你也可以創(chuàng)建你自己的對象。
    2014-09-09

最新評論