Когда я получаю АЯКС ответ от API, я получаю жесткий JSon структуру:Лучшая практика для создания html из json/js объекта?
{
object: {
key: value,
key: value,
....
key(array_of_objects): {
key: value,
key: value,
}, {
key: value,
key: value,
}, {
key: value,
key: value,
}
}
}
Теперь я делаю:
function render(json) {
var data = $.parseJSON(json);
var html = "";
html += "<h1>Hello"+data.key+"</h1>";
html += "<h2>Your data:</h2>";
html += "<ul>";
var data_array= "";
$.each(data.array_of_objects, function(index, val) {
data_array += "<li>" + val.key + "</li>";
});
html += data_array+"<ul>"
return html;
}
$.ajax({
type: "POST",
url: apiUrl,
data: request,
success: function(obj, xr, res) {
$(".content").append(render(obj));
}
})
Я знаю, что с помощью плохое решение, потому что мой код запуталась и трудно расширяемый.
И я хочу разделить логику js и html.
Что является лучшим решением для этой ситуации?
решением Лучшей практикой в вашем случае будет использовать один из шаблонов двигателей. Например, http://handlebarsjs.com/, или http://underscorejs.org/. Это позволяет вам отделить вас от кода js. –
Если вы делаете это более чем несколько раз в своем приложении, я бы сказал, продолжайте использовать Усы или Ручки. Ваш html всегда будет связан с вашими данными ответа API, но таким образом шаблоны могут быть совместимыми и многоразовыми. – prodigitalson