jquery获取元素的html怎么获取get来的HTML元素

jquery中常用的SET和GET$(”#msg”).html循环介绍
代码如下: $(”#msg”).html(); //返回id为msg的元素节点的html内容。 $(”#msg”).html(”new content“); //将“new content” 作为html串写入id为msg的元素节点内容中,页面显示粗体的new content $(”#msg”).text(); //返回id为msg的元素节点的文本内容。 $(”#msg”).text(”new content“); //将“new content” 作为普通文本串写入id为msg的元素节点内容中,页面显示new content $(”#msg”).height(); //返回id为msg的元素的高度 $(”#msg”).height(”300″); //将id为msg的元素的高度设为300 $(”#msg”).width(); //返回id为msg的元素的宽度 $(”#msg”).width(”300″); //将id为msg的元素的宽度设为300 $(”input”).val(”); //返回表单输入框的value值 $(”input”).val(”test”); //将表单输入框的value值设为test $(”#msg”).click(); //触发id为msg的元素的单击事件 $(”#msg”).click(fn); //为id为msg的元素单击事件添加函数 $.each( [0,1,2], function(i, n){ alert( "Item #" + i + ":" + n );}); [code] 等价于: [code] vartempArr=[0,1,2]; for(vari=0;i&tempArr.i++){ alert("Item#"+i+":"+tempArr[i]); }
顶一下(0) 踩一下(0)
热门标签:收藏,1.1k 浏览
问题对人有帮助,内容完整,我也想知道答案
问题没有实际价值,缺少关键内容,没有改进余地
可能是因为我说的不够清楚,我再修改下。
在js中可以这么使用:
(id名称).style.display="inline';
而不是使用:
document.getElementById('id名称').style.display="inline";
就像我在下面使用的一样,js不会报错而且还能准确执行。
&script type="text/javascript"&
var clickedItem=document.getElementById('multiNavItem1');
var subItems=document.querySelectorAll('.navItemSecondaryPack');
function showSubItem(){
for (var i=0;i&subItems.i++)
subItems[i].style.display='inline';
**multiNavItem1**.addEventListener('click',showSubItem);
其中的multiNavItem是一个div元素id, 上面没有使用clickedItem.addEventListener('click',showSubItem);
原生js直接使用id获取对应元素,这个在所有浏览器中是标准的吗?推荐使用吗?
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
8月31日 回答
这个最初是 IE 里面的,后来 firefox chrome 好像也支持了。不建议使用,这个不是标准里面的,将来不一定支持。而且代码容易写混乱了,multiNavItem1 属于全局作用域,而且你可以给他赋值,赋值之后就是那个新的值,不赋值就是那个元素的值,当有些 id 赋了值有些没有,那么有些就是这个 DOM 对象,有些不是,特别容易混乱了。
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
8月31日 回答
document.getElementById可以直接使用元素的ID,但在html5的DOM操作中,推荐使用querySlector和querySlectorAll
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
8月31日 回答
看标题有点不明所以就问题来看是,推荐使用getElementById(),所有浏览器都支持
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
8月31日 回答
html5想要搞一个类似jQuery的选择器目前各主流浏览器对此API提供了良好支持,IE需8+。详情见caniuse。
element = document.querySelector('selectors');
elementList = document.querySelectorAll('selectors');
使用这两个方法无法查找带伪类状态的元素,而且节点更新后element变量不会改变,而
element = document.getElementById('selectors');
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
8月31日 回答
可以直接这样写的id.style.display="inline";使用id相当于直接成为了window对象的属性,使用window.id可以获取,但是不推荐这种写法,还是用getElementById或者querySelector好
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
8月31日 回答
你指的是querySelectorAll吧,这个是html5引入的新API,某些浏览器是不支持的
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
8月31日 回答
楼主说的确可以直接使用元素ID直接使用,但是这个方法不是W3C标准的,在低版本的火狐根本就不支持这样的写法.
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
9月3日 回答
getElementById getElementByTagName等方法都是DOM Core的组成部分,并不专属于js,支持DOM的任何一种程序设计语言都支持他们,比如XML编写出来的文档。还有HTML-DOM,比如onclick属性,他们在DOM Core出现很久之前就为人们所熟悉了。你举的这个例子就是属于HTML-DOM,比如,我们可以把下面的语句:document.getElementById('form')简化为 document.form,类似的element.getAttribute('src')简化为element.src.HTML-DOM通常更短,但是只能用来处理web文档。
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
9月6日 回答
我感觉等native web component成熟了,就会支持并推荐使用lz说的这种写法了。每个component的作用域相对独立,不会出现1楼说的id重复而产生的问题。
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
8月31日 回答
还是用js原生的方法吧,这说不好哪天不支持了不毁了?
同步到新浪微博
分享到微博?
与我们一起探索更多的未知
专业的开发者技术社区,为用户提供多样化的线上知识交流,丰富的线下活动及给力的工作机会
加入只需一步
关闭理由:
删除理由:
忽略理由:
推广(招聘、广告、SEO 等)方面的内容
与已有问题重复(请编辑该提问指向已有相同问题)
答非所问,不符合答题要求
宜作评论而非答案
带有人身攻击、辱骂、仇恨等违反条款的内容
无法获得确切结果的问题
非开发直接相关的问题
非技术提问的讨论型问题
其他原因(请补充说明)
我要举报该,理由是:
扫扫下载 App
SegmentFault
一起探索更多未知jQuery中Ajax的get、post等方法详解
投稿:hebedich
字体:[ ] 类型:转载 时间:
前面我们讲述了jQuery中ajax的load()方法,小伙伴们反应非常好,今天我们就来讲解下jQuery中Ajax的get、post等方法,希望大家同样能够喜欢。
load()方法通常用来从Web服务器上获取静态的数据文件,然而这并不能体现ajax的全部价值。
在项目中,如果需要传递一些参数给服务器中的页面,那么可以使用$.get()或者$.post()方法(或者是$.ajax()方法)
$.get()方法使用GET方式来进行异步请求。结构为:$.get(url [, data] [, callback] [, type])
$.get()方法参数解释如下:
请求的HTML页的URL地址
data(可选)
发送至服务器的key/value数据会作为QueryString附加到请求URL中
callback(可选)
载入成功时回调函数(只有当Response的返回状态是success才调用该方法)自动将请求结果和状态传递给该方法
type(可选)
服务器端返回内容的格式,包括xml、html、script、json、text和_default
$.post()方法。
$.post()和$.get()方法的结构和使用方式相同,不过它们之间仍然有以下区别:
&GET请求会将参数跟在URL后进行传递,而POST请求则是作为HTTP消息的实体内容发送给Web服务器。
&GET方式对传输的数据有大小限制(通常不大于2KB),而使用POST方式传递的数据量要比GET方式大得多(理论上不受限制)
&GET方式请求的数据会被浏览器缓存起来,因此其他人就可以从浏览器的历史记录中读取到这些数据,例如账号和密码等。在某种情况下,GET方式会带来严重的安全性问题,而POST方式相对来说可以避免这些问题
&GET方式和POST方式传递的数据在服务器端的获取也不相同。
$.getScript():jQuery提供了此方法来直接加载js文件,与加载一个HTML片段一样简单方便,并且不需要对JavaScript文件进行处理,JavaScript文件会自动执行。
jQuery代码如下:
$(function () {
&&&&&&& $("#send").click(function () {
&&&&&&&&&&& $.getScript("test.js");
&&&&&&& });
与其他ajax方法一样,$.getScript()方法也有回调函数,它会在JavaScript文件载入成功后运行。
例如:想载入jQuery官方颜色动画插件(jquery.color.js),成功后给元素绑定颜色变化动画:
&!DOCTYPE html&
&head lang="en"&
&&& &meta charset="UTF-8"&
&&& &script type="text/javascript" src="../../js/jquery-2.1.3.js"&&/script&
&&& &style&
&&&&&&& * { margin:0; padding:0;}
&&&&&&& body { font-size:12}
&&&&&&& .comment { margin-top:10 padding:10 border:1px solid #background:#DDD;}
&&&&&&& .comment h6 { font-weight:700; font-size:14}
&&&&&&& .para { margin-top:5 text-indent:2background:#DDD;}
&&&&&&& .block{width:80height:80background:#DDD;}
&&& &/style&
&&& &title&&/title&
&button id="go"&运行&/button&
&div class="block"&&/div&
&script type="text/javascript"&
&&& $(function () {
&&&&&&& $.getScript("jquery.color.js", function () {
&&&&&&&&&&& $("#go").click(function () {
&&&&&&&&&&&&&&& $(".block").animate({backgroundColor: 'pink'}, 1000)
&&&&&&&&&&&&&&&&&&&&&&& .animate({backgroundColor: 'blue'}, 1000);
&&&&&&&&&&& });
&&&&&&& })
$.getJson():该方法用于加载JSON文件,用法与$.getScript()相同。
&!DOCTYPE html&
&head lang="en"&
&&& &meta charset="UTF-8"&
&&& &script src="../../js/jquery-2.1.3.js"&&/script&
&&& &style&
&&&&&&& * { margin:0; padding:0;}
&&&&&&& body { font-size:12}
&&&&&&& .comment { margin-top:10 padding:10 border:1px solid #background:#DDD;}
&&&&&&& .comment h6 { font-weight:700; font-size:14}
&&&&&&& .para { margin-top:5 text-indent:2background:#DDD;}
&&& &/style&
&&& &title&&/title&
&&& &input type="button" id="send" value="加载"/&
&div& class="comment"&已有评论:&/div&
&div id="resText" &
&script type="text/javascript"&
&&& $(function () {
&&&&&&& $('#send').click(function() {
&&&&&&&&&&& $.getJSON('test.json', function(data) {
&&&&&&&&&&&&&&& $('#resText').empty();
&&&&&&&&&&&&&&& var html = '';
&&&&&&&&&&&&&&& $.each( data& , function(commentIndex, comment) {
&&&&&&&&&&&&&&&&&&& html += '&div class="comment"&&h6&' + comment['username'] + ':&/h6&&p class="para"&' + comment['content'] + '&/p&&/div&';
&&&&&&&&&&&&&&& })
&&&&&&&&&&&&&&& $('#resText').html(html);
&&&&&&&&&&& })
&&&&&&& })
test.json文件为:
&&& "username": "张三",
&&& "content": "沙发."
&&& "username": "李四",
&&& "content": "板凳."
&&& "username": "王五",
&&& "content": "地板."
使用JSONP形式的回调函数来加载其他网站的JSON数据。例如:
&!DOCTYPE html&
&head lang="en"&
&&& &meta charset="UTF-8"&
&&& &script src="../../js/jquery-2.1.3.js"&&/script&
&&& &style&
&&&&&&& * { margin:0; padding:0;}
&&&&&&& body { font-size:12}
&&&&&&& .para {
&&&&&&&&&&& width:100
&&&&&&&&&&& height:100
&&&&&&&&&&& margin:5
&&&&&&&&&&& border:0;
&&& &/style&
&&& &title&&/title&
&&& &input type="button" id="send" value="加载"/&
&div id="resText" &
&script type="text/javascript"&
&&& $(function () {
&&&&&&& $('#send').click(function() {
&&&&&&&&&&& $.getJSON("=?",
&&&&&&&&&&&&&&&&&&& function(data){
&&&&&&&&&&&&&&&&&&&&&&& $.each(data.items, function( i,item ){
&&&&&&&&&&&&&&&&&&&&&&&&&&& $("&img class='para'/& ").attr("src", item.media.m).appendTo("#resText");
&&&&&&&&&&&&&&&&&&&&&&&&&&& if ( i == 3 ) {
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
&&&&&&&&&&&&&&&&&&&&&&&&&&& }
&&&&&&&&&&&&&&&&&&&&&&& });
&&&&&&&&&&&&&&&&&&& }
&&&&&&&&&&& );
&&&&&&& })
&&&& *& JSONP(JSON with Padding)是一个非官方的协议,它允许在服务器端集成Script tags返回至客户端,通过JavaScript Callback的形式实现跨域访问
&&&& *& 上述的url地址并不能请求到数据,仅用作说明。
jQuery将自动把URL里的回调函数,例如"url?callback=?"中的后一个”?“替换为正确的函数名,以执行回调函数。
JSONP(JSON with Padding)是一个非官方的协议,它允许在服务器端集成Script tags返回至客户端,通过JavaScript Callback的形式实现跨域访问。由于JSON只是一种含有简单括号结构的纯文本,因此许多通道都可以交换JSON消息。而由于同源策略的限制,开发人员不能在于外部服务器进行通信的时候使用XMLHttpRequest。而JSONP是一种可以绕过同源策略的方法,即通过使用JSON和&script&标记相结合的方法,从服务器端直接返回可执行的JavaScript函数调用或者JavaScript对象。目前JSONP已经成为各大公司的Web应用程序跨域首选。
$.ajax()方法时jQuery最底层的ajax实现。它的结构为:
$.ajax(options).该方法只有一个参数,但在这个对象里包含了$.ajax()方法所需要的请求设置以及回调函数等信息,参数以key/value的形式存在,所有参数都是可选的,
常用参数列表为:
(默认为当前页地址)发送请求的地址
请求方式(post或get)默认为get。注意其他HTTP请求方法,如PUT何DELETE也可以使用,但仅部分浏览器支持
设置请求超时时间(毫秒)。此设置将覆盖$.ajaxSetup()方法的全局设置
Object或String
发送到服务器的数据。如果不是字符串,将自动转换为字符串格式。GET请求中将附加在url后。防止这种自动转换,可以查看processData选项。对象必须为key/value格式,例如{foo1:"bar1", foo2:"bar2"}转换为&foo1=bar1&foo2=bar2。如果是数组,jQuery将自动为不同值对应同一个名称。例如{foo:["bar1", "bar2"]}转换为&foo=bar1&foo=bar2
预期服务器返回的数据类型。如果不指定,jQuery将自动根据HTTP包MIME信息返回responseXML或responseText,并作为回调函数参数传递。可用的类型如下。
xml:返回XML文档,可用jQuery处理
html:返回纯文本HTML信息;包含的script标签会在插入DOM时执行
script:返回纯文本JavaScript代码。不会自动缓存结果。除非设置了cache参数。注意在远程请求时(不在同一个域下),所有POST请求都将转为GET请求。
json:返回JSON数据
jsonp:JSONP格式。使用JSONP形式调用函数时,例如myurl?callback=?,jQuery将自动替换后一个”?“为正确的函数名,以执行回调函数。
text:返回纯文本字符串
beforeSend
发送请求前可以修改XMLHttpRequest对象的函数,例如添加自定义HTTP头。在beforeSend中如果返回false可以取消本次Ajax请求。XMLHttpRequest对象是唯一的参数。
function(XMLHttpRequest) {
  //调用本次Ajax请求时传递的options参数
请求完成后调用的回调函数(请求成功或失败时均调用)
参数:XMLHttpRequest对象和一个描述成功请求类型的字符串。
function(XMLHttpRequest, textStatue){
  //调用本次Ajax请求时传递的options参数
请求成功后调用的回调函数,有两个参数。
(1)由服务器返回,并根据dataType参数进行处理后的数据
(2)描述状态的字符串
function(data, textStatus) {
  //data可能是xmlDoc、jsonObj、html、text等
  //调用本次Ajax请求时传递的options参数
请求失败时被调用的函数。该函数有3个参数,即XMLHttpRequest对象、错误信息、捕获的错误对象(可选)。
Ajax事件函数如下:
function(XMLHttpRequest, textStatus, errorThrown) {
  //通常情况下textStatus和errorThrown只有其中一个包含信息
  //调用本次Ajax请求时传递的options参数
默认为true。表示是否触发全局Ajax事件。设置为false将不会触发全局Ajax事件,AjaxStart或AjaxStop可用于控制各种Ajax事件
您可能感兴趣的文章:
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具如果你有疑问:请点击→ 来让更多的人来帮助你!
如果你得到了帮助:请点击→
如果你有更好的解决方案:请点击→ 来帮助更多的人!
如果你有好东西、好知识:请点击→ 来分享给更多的人!

我要回帖

更多关于 jquery 获取元素位置 的文章

 

随机推荐