vue.JS 与 php 框架中 ajax 获取数据遇到的渲染问题
在 vue.js 框架中,配合 php 后端语言使用 ajax 获取数据时,有时会出现数据无法正常渲染的情况。其中,常见原因之一是数据未正确转换为 JavaScript 对象。
问题描述
<div class="box" id="box"> <p>选择项目:</p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/7fc7563c4182" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">PHP免费学习笔记(深入)</a>”;</p> <ul class="list-group"> <li class="input-group" v-for="todo in todos"> <span class="input-group-addon"> <input type="checkbox"> </span> <input type="text" class="form-control" v-bind:value="todo.value"> </li> </ul> </div>
在 php 后端中,使用了以下代码获取数据并返回 json 字符串:
$items = json_encode($todos); echo $items;
在 vue.js 中,使用 ajax 获取后端返回的 json 数据后,需要将字符串转换为 javascript 对象才能正确使用。
在 vue.js 中,可以使用以下代码转换返回的数据:
_self.todos = JSON.parse(items);
通过将返回的 json 字符串解析为 javascript 对象,vue.js 即可正确渲染数据,从而解决 ajax 获取数据后无法正常渲染的问题。