react 方法未定义_在地图函数Reactjs中,“this”未定义

在使用Reactjs构建菜单组件时,遇到在map函数内部'this'未定义的问题,导致无法访问组件的props属性。错误信息为'无法读取未定义的属性'props'。问题出现在尝试遍历menus和_children数组时,'this'上下文丢失。
摘要由CSDN通过智能技术生成

我正在使用Reactjs编写一个菜单组件。

"use strict";

var React = require("react");

var Menus = React.createClass({

item_url: function (item,categories,articles) {

console.log('afdasfasfasdfasdf');

var url='XXX';

if (item.type == 1) {

url = item.categoryId == null ? 'javascript:void(0)' : path('buex_portal_browse_category', {slug: categories[item.categoryId].slug});

} else if (item.type == 2) {

url = item.articleId == null ? 'javascript:void(0)' : path('buex_portal_view_article', {slug: articles[item.articleId].slug, id: item.articleId});

} else {

url = item.url;

}

return url;

},

render: function () {

//   console.log(this.props.menus);  // return correctly

var menuElements = this.props.menus.map(function (item1) { // return fault : 'cannot read property 'props' of undefined '

return (

{item1.name} // the same fault above

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值