苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

分布式系统框架(V2.0) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper爬虫框架(V2.7-含.netcore) HttpHelper官方出品,爬虫框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 开源的爬虫类,支持多种模式和属性 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 6418|回复: 0

[Jquery] Jquery与JS结合学习笔记

[复制链接]
发表于 2012-9-20 14:45:46 | 显示全部楼层 |阅读模式
一.选择器
[HTML] 纯文本查看 复制代码
//1.选择body选择其它的可以直接使用这个方法,一定要加上*而且中间要有空格;
$("body *")
 
//2.选择带名称的直接使用;
$("#名称必须是ID") 
 
//3.这样是选择名称为classname的所有样式;
$(".classname") 

二.方法
1.在这里我们先来说一下Ajax方法吧 在介绍使用之前我们先来了解一下关于这方面的W3c给的标准吧请看下面
  1. w3cJqueryAjax标准

  2. 参数
  3. options
  4. 类型:Object

  5. 可选。AJAX 请求设置。所有选项都是可选的。
  6. async
  7. 类型:Boolean

  8. 默认值: true。默认设置下,所有请求均为异步请求。如果需要发送同步请求,请将此选项设置为 false。

  9. 注意,同步请求将锁住浏览器,用户其它操作必须等待请求完成才可以执行。
  10. beforeSend(XHR)
  11. 类型:Function

  12. 发送请求前可修改 XMLHttpRequest 对象的函数,如添加自定义 HTTP 头。

  13. XMLHttpRequest 对象是唯一的参数。

  14. 这是一个 Ajax 事件。如果返回 false 可以取消本次 ajax 请求。
  15. cache
  16. 类型:Boolean

  17. 默认值: true,dataType 为 script 和 jsonp 时默认为 false。设置为 false 将不缓存此页面。

  18. jQuery 1.2 新功能。
  19. complete(XHR, TS)
  20. 类型:Function

  21. 请求完成后回调函数 (请求成功或失败之后均调用)。

  22. 参数: XMLHttpRequest 对象和一个描述请求类型的字符串。

  23. 这是一个 Ajax 事件。
  24. contentType
  25. 类型:String

  26. 默认值: "application/x-www-form-urlencoded"。发送信息至服务器时内容编码类型。

  27. 默认值适合大多数情况。如果你明确地传递了一个 content-type 给 $.ajax() 那么它必定会发送给服务器(即使没有数据要发送)。
  28. context
  29. 类型:Object

  30. 这个对象用于设置 Ajax 相关回调函数的上下文。也就是说,让回调函数内 this 指向这个对象(如果不设定这个参数,那么 this 就指向调用本次 AJAX 请求时传递的 options 参数)。比如指定一个 DOM 元素作为 context 参数,这样就设置了 success 回调函数的上下文为这个 DOM 元素。

  31. 就像这样:
  32. $.ajax({ url: "test.html", context: document.body, success: function(){
  33.         $(this).addClass("done");
  34.       }});
  35. dataObject
  36. 类型:String

  37. 发送到服务器的数据。将自动转换为请求字符串格式。GET 请求中将附加在 URL 后。查看 processData 选项说明以禁止此自动转换。必须为 Key/Value 格式。如果为数组,jQuery 将自动为不同值对应同一个名称。如 {foo:["bar1", "bar2"]} 转换为 '&foo=bar1&foo=bar2'。
  38. dataFilter
  39. 类型:Function

  40. 给 Ajax 返回的原始数据的进行预处理的函数。提供 data 和 type 两个参数:data 是 Ajax 返回的原始数据,type 是调用 jQuery.ajax 时提供的 dataType 参数。函数返回的值将由 jQuery 进一步处理。
  41. dataType
  42. 类型:String

  43. 预期服务器返回的数据类型。如果不指定,jQuery 将自动根据 HTTP 包 MIME 信息来智能判断,比如 XML MIME 类型就被识别为 XML。在 1.4 中,JSON 就会生成一个 JavaScript 对象,而 script 则会执行这个脚本。随后服务器端返回的数据会根据这个值解析后,传递给回调函数。可用值:
  44. •"xml": 返回 XML 文档,可用 jQuery 处理。
  45. •"html": 返回纯文本 HTML 信息;包含的 script 标签会在插入 dom 时执行。
  46. •"script": 返回纯文本 JavaScript 代码。不会自动缓存结果。除非设置了 "cache" 参数。注意:在远程请求时(不在同一个域下),所有 POST 请求都将转为 GET 请求。(因为将使用 DOM 的 script标签来加载)
  47. •"json": 返回 JSON 数据 。
  48. •"jsonp": JSONP 格式。使用 JSONP 形式调用函数时,如 "myurl?callback=?" jQuery 将自动替换 ? 为正确的函数名,以执行回调函数。
  49. •"text": 返回纯文本字符串
  50. error
  51. 类型:Function

  52. 默认值: 自动判断 (xml 或 html)。请求失败时调用此函数。

  53. 有以下三个参数:XMLHttpRequest 对象、错误信息、(可选)捕获的异常对象。

  54. 如果发生了错误,错误信息(第二个参数)除了得到 null 之外,还可能是 "timeout", "error", "notmodified" 和 "parsererror"。

  55. 这是一个 Ajax 事件。
  56. global
  57. 类型:Boolean

  58. 是否触发全局 AJAX 事件。默认值: true。设置为 false 将不会触发全局 AJAX 事件,如 ajaxStart 或 ajaxStop 可用于控制不同的 Ajax 事件。
  59. ifModified
  60. 类型:Boolean

  61. 仅在服务器数据改变时获取新数据。默认值: false。使用 HTTP 包 Last-Modified 头信息判断。在 jQuery 1.4 中,它也会检查服务器指定的 'etag' 来确定数据没有被修改过。
  62. jsonp
  63. 类型:String

  64. 在一个 jsonp 请求中重写回调函数的名字。这个值用来替代在 "callback=?" 这种 GET 或 POST 请求中 URL 参数里的 "callback" 部分,比如 {jsonp:'onJsonPLoad'} 会导致将 "onJsonPLoad=?" 传给服务器。
  65. jsonpCallback
  66. 类型:String

  67. 为 jsonp 请求指定一个回调函数名。这个值将用来取代 jQuery 自动生成的随机函数名。这主要用来让 jQuery 生成度独特的函数名,这样管理请求更容易,也能方便地提供回调函数和错误处理。你也可以在想让浏览器缓存 GET 请求的时候,指定这个回调函数名。
  68. password
  69. 类型:String

  70. 用于响应 HTTP 访问认证请求的密码
  71. processData
  72. 类型:Boolean

  73. 默认值: true。默认情况下,通过data选项传递进来的数据,如果是一个对象(技术上讲只要不是字符串),都会处理转化成一个查询字符串,以配合默认内容类型 "application/x-www-form-urlencoded"。如果要发送 DOM 树信息或其它不希望转换的信息,请设置为 false。
  74. scriptCharset
  75. 类型:String

  76. 只有当请求时 dataType 为 "jsonp" 或 "script",并且 type 是 "GET" 才会用于强制修改 charset。通常只在本地和远程的内容编码不同时使用。
  77. success
  78. 类型:Function

  79. 请求成功后的回调函数。

  80. 参数:由服务器返回,并根据 dataType 参数进行处理后的数据;描述状态的字符串。

  81. 这是一个 Ajax 事件。
  82. traditional
  83. 类型:Boolean

  84. 如果你想要用传统的方式来序列化数据,那么就设置为 true。请参考工具分类下面的 jQuery.param 方法。
  85. timeout
  86. 类型:Number

  87. 设置请求超时时间(毫秒)。此设置将覆盖全局设置。
  88. type
  89. 类型:String

  90. 默认值: "GET")。请求方式 ("POST" 或 "GET"), 默认为 "GET"。注意:其它 HTTP 请求方法,如 PUT 和 DELETE 也可以使用,但仅部分浏览器支持。
  91. url
  92. 类型:String

  93. 默认值: 当前页地址。发送请求的地址。
  94. username
  95. 类型:String

  96. 用于响应 HTTP 访问认证请求的用户名。
  97. xhr
  98. 类型:Function

  99. 需要返回一个 XMLHttpRequest 对象。默认在 IE 下是 ActiveXObject 而其他情况下是 XMLHttpRequest 。用于重写或者提供一个增强的 XMLHttpRequest 对象。这个参数在 jQuery 1.3 以前不可用。


  100. 回调函数

  101. 如果要处理 $.ajax() 得到的数据,则需要使用回调函数:beforeSend、error、dataFilter、success、complete。

  102. beforeSend

  103. 在发送请求之前调用,并且传入一个 XMLHttpRequest 作为参数。

  104. error

  105. 在请求出错时调用。传入 XMLHttpRequest 对象,描述错误类型的字符串以及一个异常对象(如果有的话)

  106. dataFilter

  107. 在请求成功之后调用。传入返回的数据以及 "dataType" 参数的值。并且必须返回新的数据(可能是处理过的)传递给 success 回调函数。

  108. success

  109. 当请求之后调用。传入返回后的数据,以及包含成功代码的字符串。

  110. complete

  111. 当请求完成之后调用这个函数,无论成功或失败。传入 XMLHttpRequest 对象,以及一个包含成功或错误代码的字符串。


  112. 数据类型

  113. $.ajax() 函数依赖服务器提供的信息来处理返回的数据。如果服务器报告说返回的数据是 XML,那么返回的结果就可以用普通的 XML 方法或者 jQuery 的选择器来遍历。如果见得到其他类型,比如 HTML,则数据就以文本形式来对待。

  114. 通过 dataType 选项还可以指定其他不同数据处理方式。除了单纯的 XML,还可以指定 html、json、jsonp、script 或者 text。

  115. 其中,text 和 xml 类型返回的数据不会经过处理。数据仅仅简单的将 XMLHttpRequest 的 responseText 或 responseHTML 属性传递给 success 回调函数。

  116. 注意:我们必须确保网页服务器报告的 MIME 类型与我们选择的 dataType 所匹配。比如说,XML的话,服务器端就必须声明 text/xml 或者 application/xml 来获得一致的结果。

  117. 如果指定为 html 类型,任何内嵌的 JavaScript 都会在 HTML 作为一个字符串返回之前执行。类似地,指定 script 类型的话,也会先执行服务器端生成 JavaScript,然后再把脚本作为一个文本数据返回。

  118. 如果指定为 json 类型,则会把获取到的数据作为一个 JavaScript 对象来解析,并且把构建好的对象作为结果返回。为了实现这个目的,它首先尝试使用 JSON.parse()。如果浏览器不支持,则使用一个函数来构建。

  119. JSON 数据是一种能很方便通过 JavaScript 解析的结构化数据。如果获取的数据文件存放在远程服务器上(域名不同,也就是跨域获取数据),则需要使用 jsonp 类型。使用这种类型的话,会创建一个查询字符串参数 callback=? ,这个参数会加在请求的 URL 后面。服务器端应当在 JSON 数据前加上回调函数名,以便完成一个有效的 JSONP 请求。如果要指定回调函数的参数名来取代默认的 callback,可以通过设置 $.ajax() 的 jsonp 参数。

  120. 注意:JSONP 是 JSON 格式的扩展。它要求一些服务器端的代码来检测并处理查询字符串参数。

  121. 如果指定了 script 或者 jsonp 类型,那么当从服务器接收到数据时,实际上是用了 <script> 标签而不是 XMLHttpRequest 对象。这种情况下,$.ajax() 不再返回一个 XMLHttpRequest 对象,并且也不会传递事件处理函数,比如 beforeSend。


  122. 发送数据到服务器

  123. 默认情况下,Ajax 请求使用 GET 方法。如果要使用 POST 方法,可以设定 type 参数值。这个选项也会影响 data 选项中的内容如何发送到服务器。

  124. data 选项既可以包含一个查询字符串,比如 key1=value1&key2=value2 ,也可以是一个映射,比如 {key1: 'value1', key2: 'value2'} 。如果使用了后者的形式,则数据再发送器会被转换成查询字符串。这个处理过程也可以通过设置 processData 选项为 false 来回避。如果我们希望发送一个 XML 对象给服务器时,这种处理可能并不合适。并且在这种情况下,我们也应当改变 contentType 选项的值,用其他合适的 MIME 类型来取代默认的 application/x-www-form-urlencoded 。


  125. 高级选项

  126. global 选项用于阻止响应注册的回调函数,比如 .ajaxSend,或者 ajaxError,以及类似的方法。这在有些时候很有用,比如发送的请求非常频繁且简短的时候,就可以在 ajaxSend 里禁用这个。

  127. 如果服务器需要 HTTP 认证,可以使用用户名和密码可以通过 username 和 password 选项来设置。

  128. Ajax 请求是限时的,所以错误警告被捕获并处理后,可以用来提升用户体验。请求超时这个参数通常就保留其默认值,要不就通过 jQuery.ajaxSetup 来全局设定,很少为特定的请求重新设置 timeout 选项。

  129. 默认情况下,请求总会被发出去,但浏览器有可能从它的缓存中调取数据。要禁止使用缓存的结果,可以设置 cache 参数为 false。如果希望判断数据自从上次请求后没有更改过就报告出错的话,可以设置 ifModified 为 true。

  130. scriptCharset 允许给 <script> 标签的请求设定一个特定的字符集,用于 script 或者 jsonp 类似的数据。当脚本和页面字符集不同时,这特别好用。

  131. Ajax 的第一个字母是 asynchronous 的开头字母,这意味着所有的操作都是并行的,完成的顺序没有前后关系。$.ajax() 的 async 参数总是设置成true,这标志着在请求开始后,其他代码依然能够执行。强烈不建议把这个选项设置成 false,这意味着所有的请求都不再是异步的了,这也会导致浏览器被锁死。

  132. $.ajax 函数返回它创建的 XMLHttpRequest 对象。通常 jQuery 只在内部处理并创建这个对象,但用户也可以通过 xhr 选项来传递一个自己创建的 xhr 对象。返回的对象通常已经被丢弃了,但依然提供一个底层接口来观察和操控请求。比如说,调用对象上的 .abort() 可以在请求完成前挂起请求。
复制代码
例子
[HTML] 纯文本查看 复制代码
//newbtn事件
    $("#newbtn").click(function () {
        var strdomin = sethead($.trim($("#site").val()));
        $.ajax({
            type: "post",
            timeout: "3000",
            contentType: "application/json; charset=utf-8",
            url: "hander/ContraryFriend.ashx",
            data: { domain: $.trim($("#site").val()), strdo: "cfquery" },
            beforeSend: function () {
                $("#show").html(loadimage);
            },
            success: function (msg) {
                $("#show").html(msg);
            },
            error: function (ms) {
                $("#show").html("未查询到反链!!!");
            }
        });
    });

三.常用的例子实现多个输入框同时输入的方法
[HTML] 纯文本查看 复制代码
//-----------------------------------------实现多个输入框同时输入的方法-----------------------------------------------
function getid(id) {
    return (typeof id == 'string') ? document.getElementById(id) : id
};
//关闭输入法
function closeIME(e) {
    var obj = e.target ? e.target : e.srcElement;
    obj.style.imeMode = 'disabled';
}
function OnPaste(e) {
    var obj = e.target ? e.target : e.srcElement;
    setTimeout("MoveHttp('" + obj.id + "')", 100);
}
function MoveHttp(id) {
    var val = getid(id).value;
    val = val.replace("http://", "");
    if (val[val.length - 1] == '/') {
        val = val.substring(0, val.length - 1);
    }
    getid(id).value = val;
}
function OnKeyup(e) {
    var obj = e.target ? e.target : e.srcElement;
    setTimeout("addInput('" + obj.id + "')", 200);
}
function addInput(id) {
    var obj = getid(id);
    //如果是一个没有True的input不执行
    if (obj.getAttribute('url') == 'true') {
        if (obj.value.indexOf('。') > 0) {
            obj.value = obj.value.replace('。', '.');
        }
        var tags = document.getElementsByTagName('input');
        for (var i = 0; i < tags.length; i++) {
            if (tags.getAttribute('url') == 'true' && tags != obj) {
                tags.value = obj.value;
            }
        }
    }
}
function BoxShowUrls(e) {
    BoxShow(e);
}
function Init() {
    $(":text").each(function () {
        $(this).bind("keyup", OnKeyup);
        //        $(this).bind("focus", closeIME);
        $(this).bind("paste", OnPaste);
        $(this)[0].setAttribute('autocomplete', 'off');
    });
}

把上面的JS原版不动的放到你的页面里然后在页面的最后调用如下
[HTML] 纯文本查看 复制代码
<script type="text/javascript"> Init();</script>

  如果你想让那个输入框有这样的效果就在那个输入框的标签里加上url="true"如下
?
<input id="txtFriendslink" url="true" name="word" type="text" class="clchinput" />

  这样效果就可以实现了,大家试试吧


四.js分析Http请求地址的方式
[HTML] 纯文本查看 复制代码
//QueryString =
//  {
//      data: {},
//      Initial: function () {
//          var aPairs, aTmp;
//          var queryString = new String(window.location.search);
//          queryString = queryString.substr(1, queryString.length); //remove "?"   
//          aPairs = queryString.split("&");
//          for (var i = 0; i < aPairs.length; i++) {
//              aTmp = aPairs.split("=");
//              this.data[aTmp[0]] = aTmp[1];
//          }
//      },
//      GetValue: function (key) {
//          return this.data[key];
//      }
//  }


把这个直接放在JS文件里,不要放在方法 里面
在使用的地方调用如下
[HTML] 纯文本查看 复制代码
////先调用才能使用QueryString
    //    QueryString.Initial();
var url=queryString.split("/");
   //先调用才能使用QueryString
    QueryString.Initial();
    var text = QueryString.GetValue('domain');
    var left = QueryString.GetValue('left');

当然如果你的URl是重写后的可以这样写
[HTML] 纯文本查看 复制代码
var aPairs, aTmp;
    var queryString = new String(window.location.href);
    queryString = queryString.substr(1, queryString.length); //remove "?"   
    aPairs = queryString.split("/");
    var text = aPairs[aPairs.length - 1];



1. 开通SVIP会员,免费下载本站所有源码,不限次数据,不限时间
2. 加官方QQ群,加官方微信群获取更多资源和帮助
3. 找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备18043678号-2)

GMT+8, 2025-1-20 01:08

© 2014-2021

快速回复 返回顶部 返回列表