【发布时间】:2015-01-03 11:38:30
【问题描述】:
我正在尝试在页面加载时使用 JavaScript 将数据加载到 div。我正在使用 jQuery Mobile。该页面使用普通的href 调用,我假设它被jQM 劫持到ajax。
但我的 JavaScript 似乎有些奇怪,所有脚本都运行(我使用 alerts 检查过),但 append 函数似乎对页面没有任何影响。各种功能我都试过了:pagecreate、pagebeforeshow、document.ready。
这是我的代码的相关部分:
<body>
<div data-role="page" id="page">
<div data-role="content" style="padding:0" data-theme="k">
<ul class="rig columns-3" style="margin:0;padding-left:0;padding-right:8px;padding-top:20vw" id="DrinkGridView">
<!-- <li>
<img src="images/logo.png" />
<h3>Image Title</h3>
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit...</p>
</li> -->
</ul>
</div><!-- /content -->
<script type="text/javascript">
//$( document ).delegate("#page", "pageinit", function() {
var global_id;
var global_data;
var fields = [];
$.ajax({
type: "POST",
url: "http://192.168.1.120/yiibootstrap_old/index.php/userregistration/makedrink",
cache: false,
success: function(data)
{
var obj = $.parseJSON(data);
$.each(obj, function()
{
fields.push({id:this['id'],name:this['name'],image:this['image'],Description:this['description']});
});
var count = fields.length;
count1 = parseInt(count);
for (var r = 0; r < count1; r++)
{
$('#DrinkGridView').append('<a id="inline" href=#data><li id="' + fields[r]['id'] + '"> <img src="http://192.168.1.120/yiibootstrap_old/uploads/' + fields[r]['image'] + '"/> <h3><b>' + fields[r]['name'] + '</h3> <p id="sss">' + fields[r]['Description'] + '</p> </li></a>').children().last().trigger("create");
// THIS APPEND IS NOT SHOWING RESULT !!
}
});
//});
</script>
</div><!-- /page -->
</body>
【问题讨论】:
-
在您的代码中,ajax 没有正确关闭
-
它已关闭,我只是在删除一些发布代码时错过了它。代码运行没有错误,但 apppend 方法似乎没有任何效果。
-
在没有
.children().last().trigger("create")的情况下追加是否有效?还要把a放在li里面而不是外面。 -
在我的测试页面中使用了带有虚假字段的附加代码。这完美无缺。您的
fields对象是否包含任何数据? -
您使用的是哪个 jQM 版本?
标签: javascript jquery html cordova jquery-mobile