任何人都可以在这里提供帮助,我正在使用一个数组来分割一些数据,并且在附加到的视图上我得到了上面的错误.
这是我的代码:
用于ajax视图的PHP:
$images = array();
$data_link = array();
$data_id = array();
$data_likes = array();
$data_text = array();
foreach ($media as $data) {
//dd($data->caption);
$images[] = array(
//dd($data->caption),
"data_url"=>$data->images->standard_resolution->url,
"data_link"=>$data->link,
"data_text" => $data->caption['text'],
"data_id"=>$data->getId(),
"data_likes"=>$data->likes->count,
"data_like"=>$current_user->likes($data),
"data_token"=>$token
);
}
echo json_encode(array(
'next_id' => $media->getNextMaxTagId(),
'images' => $images
));
Run Code Online (Sandbox Code Playgroud)
然后我使用加载更多按钮访问数据.当我调试代码时,$data->caption我得到这个:
object(stdClass)#62 (4) {
["created_time"]=>
string(10) "1377775401"
["text"]=>
string(48) "New arrival #folkclothing reversible knit/jacket"
["from"]=>
object(stdClass)#63 (4) {
["username"]=>
string(18) "vanmildertclothing"
["profile_picture"]=>
string(76) "http://images.ak.instagram.com/profiles/profile_24567722_75sq_1342623790.jpg"
["id"]=>
string(8) "24567722"
["full_name"]=>
string(11) "Van Mildert"
}
["id"]=>
string(18) "533141169038331174"
}
Run Code Online (Sandbox Code Playgroud)
有谁知道我为什么会收到这个错误?
在此编辑,因为错误不符合预期
ajax jquery的调用如下:
$('#more').click(function() {
var tag = $(this).data('tag'),
maxid = $(this).data('maxid');
$.ajax({
type: 'GET',
url: '/ajax',
data: {
tag: tag,
max_tag_id: maxid
},
dataType: 'json',
cache: false,
complete: function(){
},
success: function(data) {
// Output data
$.each(data.images, function(i, src) {
var $content = $('<article class="instagram-image"><form id="'+ data.images[i].data_token +'" class="forms status-'+ data.images[i].data_like +'" action="'+base+'" method="post"><a class="fancybox" rel="folk-1" href="' + data.images[i].data_url + '"><img alt="' + data.images[i].data_text + '" src="' + data.images[i].data_url + '" alt="' + data.images[i].data_text + '" /></a><div class="formSubmit-feedback"></div><input type="hidden" name="id" value="'+ data.images[i].data_id +'"><p>'+ data.images[i].data_likes +'</p></form></article>');
var duration = 1000, n = 0.1;
$content.appendTo('section#images');
$item = $content.find('form');
if( $item.hasClass("status-false") ){
$item.addClass("notLiked");
//$('.notLiked').find('button.unlike').hide();
$item.find('a').after('<button class="ajax instabtn button-like like icon-heart" type="submit" name="action" value="Like"></button>');
}
if( $item.hasClass("status-true") ){
$item.addClass("Liked");
//$('.Liked').find('button.like').hide();
$item.find('a').after('<button class="ajax instabtn button-unlike unlike icon-heart" type="submit" name="action" value="Unlike"></button>');
}
});
// Store new maxid
$('#more').data('maxid', data.next_id);
},
error:function(){
$('#error-panel').html('<p class="error"><strong>Oops!</strong> Try that again in a few moments.</p>');
}
});
});
Run Code Online (Sandbox Code Playgroud)
在页面上我有一个按钮,可以将更多的instagram图像加载到容器中,它可以正常使用其他所有内容,但不能使用我试图访问的标题 - >文本.如果我去url/ajax我得到了我想要的数据,它显示了text_data数组中的文本,但是当它从加载到图像中加载时,我得到了那个错误.
这是我得到的确切错误:
Error rendering view: [instagram.ajax]Trying to get property of non-object
并不像我最初想的那么简单.
正如它所说:$data->caption是一个对象,但你正试图像使用数组一样访问它$data->caption['text'].像对象一样访问它:
$data->caption->text
Run Code Online (Sandbox Code Playgroud)
$data->caption 是一个对象,但您的代码正在尝试访问它,就好像它是一个数组.
更改$data->caption['text']到$data->caption->text