Javascript 如何使用jQuery将查询字符串传递给Ajax调用?

Javascript 如何使用jQuery将查询字符串传递给Ajax调用?,javascript,jquery,query-string,Javascript,Jquery,Query String,这是一个后续行动 我从数据库中获取项,并将它们显示在for循环中。我使用jQuery隐藏其中一行。现在我需要获取隐藏行的main\u id,并将其传递给$.ajax。在最初的问题中,Paul建议使用alert(this.attr(“title”)但是此行停止执行$.ajax调用,并且该调用不会执行。当我注释掉警报警报(this.attr(“title”)然后ajax调用通过。在这种情况下,我会得到一个错误,因为处理程序中的display\u false()函数没有获取main\u id的值 这是

这是一个后续行动

我从数据库中获取
,并将它们显示在for循环中。我使用jQuery隐藏其中一行。现在我需要获取隐藏行的
main\u id
,并将其传递给
$.ajax
。在最初的问题中,Paul建议使用
alert(this.attr(“title”)
但是此行停止执行
$.ajax
调用,并且该调用不会执行。当我注释掉警报
警报(this.attr(“title”)然后ajax调用通过。在这种情况下,我会得到一个错误,因为处理程序中的
display\u false()
函数没有获取
main\u id
的值

这是带有
标题=%s
的“隐藏”链接的html

<a class="false" title=%s href="/useradminpage?main_id=%s&display=false"><span class="small">(hide)</span></a>
HTML

#-----------main table------------#
            main_id = self.request.get("main_id")

            self.response.out.write("""<table class="mytable">
            <tr class="head">
            <th  width="80%">links</th><th>edit tags</th>
            </tr>    
            """)        

            query = Main.all()
            query.filter("owner", user)
            query.filter("display", True)
            query.order("-date")
            cursor = self.request.get("cursor")
            if cursor: query.with_cursor(cursor)
            e = query.fetch(100)
            cursor = query.cursor()

            for item in e:
                main_id = item.key().id()
                self.response.out.write("""
                <tr class="hide">
                <td><a href="%s" target="_blank">%s</a><span class=small> (%s) </span><br />
                <span class=small>%s</span>
                <a href="/edit?main_id=%s"><span class="small">(edit)</span></a>
                <a class="false" title=%s href="/useradminpage?main_id=%s&display=false"><span class="small">(hide)</span></a>
                <a href="/comment?main_id=%s"><span class="small">(comments)</span></a></td>
                <td><a href="/tc?url=%s&main_id=%s&user_tag_list=%s" title="edit tags">%s</a>
                </td>
                </tr>
                """ % tuple([item.url, item.title, urlparse(item.url).netloc,
                f1.truncate_at_space(item.pitch), main_id, 

                main_id,

                main_id, main_id,
                item.url, main_id, (", ".join(item.tag_list)),
                (", ".join(item.tag_list)),]))

            self.response.out.write("""</tbody></table>""")    

            display = self.request.get("display")

            def display_false():
                if display == "false":
                    main_id = self.request.get("main_id")
                    #I tried to get the "title" but this does not work
                    #main_id = self.request.get("title")
                    k = Main.get_by_id(int(main_id))
                    k.display = False                    
                    k.put()

            display_false()    
            ...
#--------------主表------------#
main\u id=self.request.get(“main\u id”)
self.response.out.write(“”)
linksedit标签
""")        
query=Main.all()
query.filter(“所有者”,用户)
query.filter(“显示”,True)
查询订单(“-日期”)
cursor=self.request.get(“cursor”)
if cursor:query.with_cursor(游标)
e=query.fetch(100)
cursor=query.cursor()
对于e中的项目:
main_id=item.key().id()
self.response.out.write(“”)
(%s)
% “”%tuple([item.url,item.title,urlparse(item.url).netloc, f1.在主\u id的\u空间(item.pitch)截断\u, 主标识, 主id,主id, item.url,main_id,(“,”.join(item.tag_list)), (“,”.join(item.tag_list)),])) self.response.out.write(“”) display=self.request.get(“display”) def display_false(): 如果显示==“false”: main\u id=self.request.get(“main\u id”) #我试图得到“标题”,但这不起作用 #main\u id=self.request.get(“标题”) k=Main.get_by_id(int(Main_id)) k、 显示=假 k、 put() 显示错误() ...
更新

根据更新了代码。现在,由于某种原因,DocumentReady没有加载,隐藏行的调用也不起作用,但是更新数据库的ajax调用起作用了。我做错了什么

<script>

$(document).ready(function() {

    alert("1 - document ready is called")
    $("a.false").click(function(e) {
        $(this).closest("tr.hide").hide("slow");
        var main_id = this.attr("title");
        var display = "false";
        e.preventDefault();
        alert("2 - row is hidden")
    });

    $("a.false").click(function() {
        alert("3 - ajax");

        $.ajax({
            url: "/useradminpage?main_id=%s&display=false",
            data: {main_id: "main_id", display: "display")},
            success: function(data) {
            display_false()
            alert(4 - "returned");
            }
        });
    });
});


</script>

$(文档).ready(函数(){
警报(“1-调用文件准备就绪”)
$(“a.false”)。单击(函数(e){
$(this).closest(“tr.hide”).hide(“slow”);
var main_id=此.attr(“标题”);
var display=“false”;
e、 预防默认值();
警报(“2-行被隐藏”)
});
$(“a.false”)。单击(函数(){
警报(“3-ajax”);
$.ajax({
url:“/useradminpage?主\u id=%s&display=false”,
数据:{main_id:“main_id”,display:“display”)},
成功:功能(数据){
显示错误()
警报(4-“返回”);
}
});
});
});

您不需要提醒该值,您需要传递它。当前您正在传递字符串
title

    $.ajax({
        url: "/useradminpage?main_id=%s&display=false",
        data: {main_id: this.attr("title")}
        success: function(data) {
        display_false()
        alert(4 - "returned");
        }
    });

$(文档).ready(函数(){
警报(“1-调用文件准备就绪”)
$(“a.false”)。单击(函数(e){
$(this).closest(“tr.hide”).hide(“slow”);
var main_id=此.attr(“标题”);
var display=“false”;
e、 预防默认值();
警报(“2-行被隐藏”)
});
$(“a.false”)。单击(函数(){
警报(“3-ajax”);
$.ajax({
url:“/useradminpage?主\u id=%s&display=false”,
数据:{main_id:“main_id”,display:“display”)},
成功:功能(数据){
显示错误()
警报(4-“返回”);
}
});
});
});

@James Montagne:谢谢你的回答。我注意到我需要从隐藏函数的第一次单击中获取
main\u id
,否则
main\u id
始终是列表中最后一项的id。但现在隐藏函数不起作用,尽管数据库正在更新。有什么建议吗?我还在数据行的末尾添加了一个逗号。对吗?我用更新的代码编辑了这个问题。再次感谢。很抱歉,有一个额外的括号,文档准备就绪现在正在加载,但隐藏功能仍然不起作用。
    $.ajax({
        url: "/useradminpage?main_id=%s&display=false",
        data: {main_id: this.attr("title")}
        success: function(data) {
        display_false()
        alert(4 - "returned");
        }
    });
<script>

$(document).ready(function() {

    alert("1 - document ready is called")
    $("a.false").click(function(e) {
        $(this).closest("tr.hide").hide("slow");
        var main_id = this.attr("title");
        var display = "false";
        e.preventDefault();
        alert("2 - row is hidden")
    });

    $("a.false").click(function() {
        alert("3 - ajax");

        $.ajax({
            url: "/useradminpage?main_id=%s&display=false",
            data: {main_id: "main_id", display: "display")},
            success: function(data) {
            display_false()
            alert(4 - "returned");
            }
        });
    });
});


</script>