o(╥﹏╥)o低级错误之ejs对象undefined

ejs页面,我写了一个for循环想打印出某数组对象中的属性,但一直报属性name undefined错误,

以下是错误代码

<% for(var i= 0;i<=locals.data.menuList.length;i++){%>
    <li class="layui-nav-item layui-nav-itemed">
        <a href="#" title="<%= locals.data.menuList[i]%>">
            <%= JSON.stringify(locals.data.menuList[i].name)%>
        </a>
    </li>
<% }%>

然后我试着直接打印,确定locals.data.menuList[i].name 是[Objdect Objdect],而JSON.stringify(locals.data.menuList[i]打印出具体整个对象包括属性,偏偏只要一加上name属性就报错.

千找万找,直到找到这个贴https://segmentfault.com/q/1010000007474502

(╯‵□′)╯︵┻━┻

 我去,既然是for循环溢出了,应该是i<locals.data.menuList.length.....

好吧,写代码不能粗心大意。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
EJS(Embedded JavaScript)是一种基于JavaScript的模板引擎,可以用来生成HTML、XML等文档。EJS提供了一种简单的方式来将数据嵌入到HTML页面中。其中,include指令用于在EJS模板中引入其他模板文件。 使用include指令,需要在模板中使用以下语法: ``` <% include path/to/other/template.ejs %> ``` 其中,path/to/other/template.ejs是要引入的模板文件的路径。注意,在使用include指令时,被引入的模板文件中不应该包含任何与当前模板文件相同的变量或函数,否则可能会导致冲突。 需要注意的是,EJS并没有内置的include功能,而是通过在模板中定义一个自定义的include函数来实现的。因此,在使用include指令之前,需要在程序中定义这个函数。下面是一个例子: ``` const ejs = require('ejs'); const fs = require('fs'); ejs.filters.include = function (path) { const file = fs.readFileSync(path, 'utf8'); return ejs.render(file, this); }; const template = ` <html> <head> <title>Example</title> </head> <body> <% include path/to/other/template.ejs %> </body> </html>`; const data = { name: 'John' }; const output = ejs.render(template, data); console.log(output); ``` 在上面的例子中,我们首先定义了一个自定义的include函数,然后在模板中使用include指令来引入其他模板文件。当渲染模板时,EJS会自动调用include函数来处理这些指令,并将被引入的模板文件和当前模板文件的数据合并起来生成最终的HTML输出。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值