js源代码:
function digg(id, flag) {
$.ajax({
type: "post",
url: "/Service/ChangLog.asmx/GetChangDigg",
data: {
id: id,
flag: flag,
n: new Date()
},
error: function () {
return false;
},
success: function (data) {
if (flag == "true") {
$("#yes[name='3']").html(data);
} else {
$("#no").html(data);
}
}
});
};
html源代码:
<span id="yes" type="yes" name="3">0</span>
这句$("#yes[name='3']").html(data);
可以实现改变id=“yes”并且name=“3”这个标签的值
现在想实现改变<span id="yes" type="yes" name="<%=id%>">0</span>
这个标签的值,js中的$("#yes[name='3']").html(data);的3换成data里的id
如何写?
$("#yes[name=id]").html(data);或$("#yes[name=‘“id”’]").html(data);这样都是错的。id是data: {
id: id,
flag: flag,
n: new Date()
},
这个代码里的。请高手帮忙,谢谢。
$.post、$.get是一些简单的方法,如果要处理复杂的逻辑,还是需要用到jQuery.ajax() 。
$.ajax的一般格式
$.ajax({
type: 'POST',
url: url ,
data: data ,
dataType:dataType ,
success: success ,
error: error
});
扩展资料
$.ajax的参数描述
参数 描述
url 必需。规定把请求发送到哪个 URL。
data 可选。映射或字符串值。规定连同请求发送到服务器的数据。
success(data, textStatus, jqXHR) 可选。请求成功时执行的回调函数。
dataType
可选。规定预期的服务器响应的数据类型。
默认执行智能判断(xml、json、script 或 html)。
$.ajax需要注意的一些地方:
1、data主要方式有三种,html拼接的,json数组,form表单经serialize()序列化的;通过dataType指定,不指定智能判断。
2、$.ajax只提交form以文本方式,如果异步提交包含<file>上传是传过不过去,需要使用jquery.form.js的$.ajaxSubmit
其实js代码里id是可以直接用的,所以我改成$("#yes[name=id]").html(data);结果错误。
改成$("#yes[name=data.val[0]]").html(data);这样也是错误的。
大哥val是我假设的......你还真实在 我又看不见你后台代码
追问呵呵,相关代码我不是都贴出来了了吗?请看js代码中data里的flag在 if (flag == "true") 中有直接用,但是$("#yes[name=id]").html(data);这样用是错误的,同理你那个也是错误的。
追答success : function(data){
//o_zmc,o_clmc,o_task,o_seq,o_ruledate
$.each(data.list,function(i,v){
var $div = $("#"+v[0]);
date = v[4];
goSpan($div,v[3],v[1],v[2],v[5]);
});
$("#date").val(date);
//alert("规则日期:"+date);
}
这是我上个项目的代码 自己看吧
我后台是java的返回一个List类型的变量list
前台直接data.list就是了
$.each用来遍历
这个代码我读懂也还是用不上啊,还是非常感谢!
追答你没设置dataType 最好指定一下
你后台返回什么东西
######################################################
dataType
预期服务器返回的数据类型。如果不指定,jQuery 将自动根据 HTTP 包 MIME 信息来智能判断,比如XML MIME类型就被识别为XML。在1.4中,JSON就会生成一个JavaScript对象,而script则会执行这个脚本。随后服务器端返回的数据会根据这个值解析后,传递给回调函数。可用值:
$.ajax()函数依赖服务器提供的信息来处理返回的数据。如果服务器报告说返回的数据是XML,那么返回的结果就可以用普通的XML方法或者jQuery的选择器来遍历。如果见得到其他类型,比如HTML,则数据就以文本形式来对待。
通过dataType选项还可以指定其他不同数据处理方式。除了单纯的XML,还可以指定 html、json、jsonp、script或者text。
其中,text和xml类型返回的数据不会经过处理。数据仅仅简单的将XMLHttpRequest的responseText或responseHTML属性传递给success回调函数,
注意,我们必须确保网页服务器报告的MIME类型与我们选择的dataType所匹配。比如说,XML的话,服务器端就必须声明 text/xml 或者 application/xml 来获得一致的结果。
如果指定为html类型,任何内嵌的JavaScript都会在HTML作为一个字符串返回之前执行。类似的,指定script类型的话,也会先执行服务器端生成JavaScript,然后再把脚本作为一个文本数据返回。
如果指定为json类型,则会把获取到的数据作为一个JavaScript对象来解析,并且把构建好的对象作为结果返回。为了实现这个目的,他首先尝试使用JSON.parse()。如果浏览器不支持,则使用一个函数来构建。JSON数据是一种能很方便通过JavaScript解析的结构化数据。如果获取的数据文件存放在远程服务器上(域名不同,也就是跨域获取数据),则需要使用jsonp类型。使用这种类型的话,会创建一个查询字符串参数 callback=? ,这个参数会加在请求的URL后面。服务器端应当在JSON数据前加上回调函数名,以便完成一个有效的JSONP请求。如果要指定回调函数的参数名来取代默认的callback,可以通过设置$.ajax()的jsonp参数。
我只想知道问题补充中怎么写$("#yes[name=id]").html(data);这句话才能编译正确。谢谢
追答$("#yes[name=“+data.id+”]").html(data);
你得让我知道你返回的什么 返回的什么类型才好判断啊
不对哦,和返回什么没有关系啊
追答$("#yes[name=‘“+id+”’]").html(data);
行了 阿门 没看见补充 俩data搞错了
+附近的双引号旁边还有个单引号
这个id不是data里的id 是函数参数的id
应该可以
呵呵,你就是高手啊,太感谢了!
本回答被提问者采纳怎么弄啊?直接写出来啊。
谢谢你的回答,但我的问题问的比较具体,希望能有具体的回答,这样的答案对我没有帮助。