ฉันกำลังพัฒนาแอพเกมและใช้ Symfony 2.0 ฉันมีคำขอ AJAX จำนวนมากไปยังแบ็กเอนด์ และการตอบสนองเพิ่มเติมคือการแปลงเอนทิตีเป็น JSON ตัวอย่างเช่น:
class DefaultController extends Controller
{
public function launchAction()
{
$user = $this->getDoctrine()
->getRepository('UserBundle:User')
->find($id);
// encode user to json format
$userDataAsJson = $this->encodeUserDataToJson($user);
return array(
'userDataAsJson' => $userDataAsJson
);
}
private function encodeUserDataToJson(User $user)
{
$userData = array(
'id' => $user->getId(),
'profile' => array(
'nickname' => $user->getProfile()->getNickname()
)
);
$jsonEncoder = new JsonEncoder();
return $jsonEncoder->encode($userData, $format = 'json');
}
}
และคอนโทรลเลอร์ทั้งหมดของฉันก็ทำสิ่งเดียวกัน: รับเอนทิตีและเข้ารหัสฟิลด์บางส่วนเป็น JSON ฉันรู้ว่าฉันสามารถใช้ Normalizers และเข้ารหัสสิทธิ์ทั้งหมดได้ แต่จะเกิดอะไรขึ้นหากเอนทิตีวนรอบลิงก์ไปยังเอนทิตีอื่น หรือกราฟเอนทิตีใหญ่มาก? คุณมีข้อเสนอแนะใด?
ฉันคิดถึงสคีมาการเข้ารหัสสำหรับเอนทิตี ... หรือใช้NormalizableInterface
เพื่อหลีกเลี่ยงการขี่จักรยาน .. ,