JQUERY-自定义插件-ajax-跨域访问

正课:

1. ***自定义插件:

2. Ajax

3. *****跨域访问:

1. ***自定义插件:

 前提: 已经html,css,js实现

 2风格:

  1. jQueryUI侵入式:

    1. css应提取到独立css文件中

      强调: 所有插件内的子元素选择器都要以插件父元素class开头,避免与其他插件冲突。

    2. 定义独立的js文件:

     1. 判断是否引入jQuery

     2. jQuery原型对象中添加插件函数

       1. 侵入class和自定义扩展属性

       2. 绑定事件

    3. 使用插件:

      引入插件.css,

      按插件要求编写HTML内容

      引入jQuery

      引入插件.js

      编写自定义脚本: 查找插件父元素,调用插件API

  2. Bootstrap DIV:

    1. css应提取到独立css文件中: jQueryUI方式

    2. 定义独立的js文件:

      强调: 不需要添加函数,不用侵入

    3. 使用插件:

      引入插件.css

      按插件要求编写HTML内容

      HTML元素,手动添加class自定义扩展属性

      引入jQuery

      引入插件.js

      强调: 不需要调用任何插件函数

2. Ajax:

 $.ajax({

  type:"get/post",

  url:"xxx.php",

  data: 查询字符串/{ 参数:, 参数:, ...}/$form.serialize(),

  dataType:"json"//如果返回json,则自动转为对象,

  success:function(data){ //请求响应结束且成功

  },

  error:function(){ //请求响应结束,但出错

  },

  complete:function(){ //只要请求响应结束

  }

 })//3.x

  .then(function(data){ ... })

 dataType: 如果服务端定义了响应的内容类型为applicaton/json, 则$.ajax自动转换不必dataType

 $.get("url", data, function(data){...}, dataType)

  $(parent).load("url",function(){ ... }) 返回内容,填充到parent

  $.getJSON()

  $.getScript()

 $.post()

3. *****跨域请求:

 什么是跨域:

  1. 域名不同, 2. 二级域名不同, 3. 端口号不同, 4. 协议

 问题: 服务端不允许xhr对象跨域发送ajax请求

 解决: 利用可以跨域的元素(link, script, iframe, img, ... )

  1.script变通实现跨域请求:

   JSONP: JSON with padding 填充json

   方案1:

     服务端: 将返回的数据,填充在一条js语句中返回

     客户端: script src="http://xxx/xx.php"

    问题: 客户端数据的处理逻辑在服务端写死的众口难调

   方案2:

     服务端: 返回一条函数调用的js语句,将数据作为参数

     客户端: 提前定义和服务端同名js函数

    问题: 函数名是在服务器端定死的

   方案3: 

     服务端: 接受客户端传入的函授名参数(callback)

            返回结果中动态拼接函数名

     客户端: script src="xxx.php?callback=函数"

    问题: script写死的,只能在页面加载时发送一次请求

   方案4:

     客户端: 不要写死script

         处理函数中,动态创建script,发送请求

         处理函数结尾,删除动态创建的script

    问题: 和传统ajax不一致!

   方案5:

    $.ajax({

      type:"",

      url:"",

      data:...,

      dataType:"jsonp",

      success:function(){

        

      }

    })

  2. 通过服务器端开放跨域:

   php: header('Access-Control-Allow-Origin:http://请求来自的网址');

正课:

1. ***自定义插件:

2. Ajax

3. *****跨域访问:

1. ***自定义插件:

 前提: 已经html,css,js实现

 2风格:

  1. jQueryUI侵入式:

    1. css应提取到独立css文件中

      强调: 所有插件内的子元素选择器都要以插件父元素class开头,避免与其他插件冲突。

    2. 定义独立的js文件:

     1. 判断是否引入jQuery

     2. jQuery原型对象中添加插件函数

       1. 侵入class和自定义扩展属性

       2. 绑定事件

    3. 使用插件:

      引入插件.css,

      按插件要求编写HTML内容

      引入jQuery

      引入插件.js

      编写自定义脚本: 查找插件父元素,调用插件API

  2. Bootstrap DIV:

    1. css应提取到独立css文件中: jQueryUI方式

    2. 定义独立的js文件:

      强调: 不需要添加函数,不用侵入

    3. 使用插件:

      引入插件.css

      按插件要求编写HTML内容

      HTML元素,手动添加class自定义扩展属性

      引入jQuery

      引入插件.js

      强调: 不需要调用任何插件函数

2. Ajax:

 $.ajax({

  type:"get/post",

  url:"xxx.php",

  data: 查询字符串/{ 参数:, 参数:, ...}/$form.serialize(),

  dataType:"json"//如果返回json,则自动转为对象,

  success:function(data){ //请求响应结束且成功

  },

  error:function(){ //请求响应结束,但出错

  },

  complete:function(){ //只要请求响应结束

  }

 })//3.x

  .then(function(data){ ... })

 dataType: 如果服务端定义了响应的内容类型为applicaton/json, 则$.ajax自动转换不必dataType

 $.get("url", data, function(data){...}, dataType)

  $(parent).load("url",function(){ ... }) 返回内容,填充到parent

  $.getJSON()

  $.getScript()

 $.post()

3. *****跨域请求:

 什么是跨域:

  1. 域名不同, 2. 二级域名不同, 3. 端口号不同, 4. 协议

 问题: 服务端不允许xhr对象跨域发送ajax请求

 解决: 利用可以跨域的元素(link, script, iframe, img, ... )

  1.script变通实现跨域请求:

   JSONP: JSON with padding 填充json

   方案1:

     服务端: 将返回的数据,填充在一条js语句中返回

     客户端: script src="http://xxx/xx.php"

    问题: 客户端数据的处理逻辑在服务端写死的众口难调

   方案2:

     服务端: 返回一条函数调用的js语句,将数据作为参数

     客户端: 提前定义和服务端同名js函数

    问题: 函数名是在服务器端定死的

   方案3: 

     服务端: 接受客户端传入的函授名参数(callback)

            返回结果中动态拼接函数名

     客户端: script src="xxx.php?callback=函数"

    问题: script写死的,只能在页面加载时发送一次请求

   方案4:

     客户端: 不要写死script

         处理函数中,动态创建script,发送请求

         处理函数结尾,删除动态创建的script

    问题: 和传统ajax不一致!

   方案5:

    $.ajax({

      type:"",

      url:"",

      data:...,

      dataType:"jsonp",

      success:function(){

        

      }

    })

  2. 通过服务器端开放跨域:

   php: header('Access-Control-Allow-Origin:http://请求来自的网址');

原文地址:https://www.cnblogs.com/QiliPING9/p/9028095.html