我正在开发一个严重依赖jQuery进行用户交互的应用程序。
(如果你的浏览器不支持jQuery,那么升级或不使用我的应用程序:)第1部分:jQuery - > MySQL - > jQuery - > HTML
正常情况下,有一个函数可以从表中获取,设置和删除数据。
在我的应用程序中,我GET'ing并设置了很多没有页面重新加载的信息。为此,我主要使用jQuery.post。
在我的JS文件的典型代码如下所示:
jQuery.post("mypath/jquery_getset_data.php", { instance: 'getItems_A', itemID: itemID_value},
function(data) {
populateItemList(data);
});
的jquery_getset_data.php包含许多如果声明:
if($_POST['instance'] == 'getItems_A'){
// PHP code to get and process data from MySQL DB
}
if($_POST['instance'] == 'setItems_A'){
// PHP code to process and insert data to MySQL DB
}
我的问题是:
对于JS文件和jquery_getset_data.php之间的交互是否更好?
如何在createStoreList中动态调用不同的“remove item”函数?见更新1
更新1: 这是我用它来创建许多不同的列表中的代码。
function createStoreList(data)
{
var ul = jQuery("<ul/>");
// We need to build the html structure in order for this to be registered in DOM.
// If we don't, jQuery events like .click, .change etc. will not work.
for (var i = 0; i < data.length; i++)
{
ul.append(
jQuery("<li/>")
.attr("id", "listItem_"+data[i].id)
.append(jQuery("<span/>")
.addClass("btnRemoveItem")
.attr("title", "Remove store from list")
.attr("id", data[i].id)
.click(function() { removeItemA(this); })
)
.append(data[i].name + ', ' + data[i].street)
);
}
return ul;
}
更新2 我想我只可以使用switch语句。我测试过它,它工作。
.click(function() {
switch(instance)
{
case 'removeListItemA': removeListItemA(this); break;
case 'removeListItemA': removeListItemB(this); break;
case 'removeListItemA': removeListItemC(this); break;
}
})
也许你应该发布“几乎相同的代码”的例子?顺便说一句,你违反了怪胎代码,不在你的笑脸附近嵌套parens:它应该阅读“或不使用我的应用程序:)):D:D – jrharshath 2009-06-22 10:12:58
+1”如果你的浏览器不支持jQuery,那么升级或不使用我的应用程序“。 :-) – KyleFarris 2009-06-22 15:10:28