3
当请求是ajax时,我正在渲染内容部分并将其插入到DOM中。它按预期工作。在ajax请求上渲染多个刀片视图部分
但是..我找不到方法,如何在同一时间渲染多个部分,如content
和title
等。
控制器:
public function awesome(Request $request) {
if($request->ajax()){
return view('awesome')->renderSections()['content'];
}
return view('awesome');
}
Ajax和pushState的
var load = function (url) {
$.get(url).done(function (data) {
$("#content").html(data);
})
};
$(document).on('click', 'a[data-request="push"]', function (e) {
e.preventDefault();
var $this = $(this),
url = $this.attr("href"),
title = $this.attr('title');
history.pushState({
url: url,
title: title
}, title, url);
// document.title = title;
load(url);
});
layouts.app
<title>@yield('title')</title>
<meta name="description" content="@yield('desc')"/>
<a data-request="push" title="AWESOME" href="<?= url('/'); ?>/awesome">Awesome</a>
<a data-request="push" title="RANDOM" href="<?= url('/'); ?>/random">Random</a>
<div id="content">
@yield('content')
</div>
刀片:
@extends('layouts.app')
@section('title', 'Awesome')
@section('desc', 'About awesome')
@section('content')
some text from awesome page
@endsection
问:
如何呈现在同一时间两个或更多的人?我应该使用数组还是其他?请举例或完整的解释。
感谢您的任何答案。
我已经做了同样的,但而不是返回响应,我编码视图,然后在Ajax请求,我正在使用''data = $ .parseJSON(data)''。但我认为那是一样的。也许response()会更“'拉拉维尔”的东西。你怎么想? – Tauras
$ .parseJson只有在返回一个json字符串时才会有效。这是通过响应json方法完成的。其次,响应json还将内容类型设置为“application/json”。最后,确保从控制器而不是字符串返回响应或视图。这是技术上正确的方法:) – Paras
好的,谢谢。最后两天,我为了这个,Ban了my头。 – Tauras