- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在阅读 React 书中的下一章时,我决定尝试构建一些代码来测试 props 在 React 中的工作原理。我有以下应用程序:
import React, { Component } from 'react';
import logo from './logo.svg';
import './App.css';
// Import Component
import PropExample from './simple-props'
const ctitle = "Sample app"
class App extends Component {
render() {
return (
<div className="App">
<header className="App-header">
<img src={logo} className="App-logo" alt="logo" />
<h1 className="App-title">{ctitle}</h1>
</header>
<p className="App-intro">
To get started, edit <code>src/App.js</code> and save to reload.
</p>
<div className='custom-components-list'>
<PropExample />
</div>
</div>
);
}
}
export default App;
组件PropExample
正在利用容器/容器设计模式。因此它有两个组件 PropX
和 Card
。 PropX 父级从 api 获取数据并更新其状态。卡通过 props 接收该数据并渲染它。
两个组件的代码如下:
/*
Simple component to read from api and present data
Propx to get data from api and function as container to Card component
Card component to present data to UI and leverage material ui
*/
import React, {Component} from 'react'
import Card from './card'
class PropX extends Component{
constructor(props){
super(props)
state:{
data:[{
name: 'Grrot',
city: "grav",
zip: 32453
},{
name: 'Grrot',
city: "grav",
zip: 32453
},{
name: 'Grrot',
city: "grav",
zip: 32453
}]
}
}
//Lifecycle hook that will grab data right before component is mounted to the dom
componentWillMount(){
let url = 'https://jsonplaceholder.typicode.com/users'
fetch(url)
.then((res)=>{ // Note that this a response object, need to look more into promises, fetch api and response object in javascript
//console.log(`The response is ${res}`)
return res.json()
})
.then(data => {
//console.log(`The data is ${data}`)
this.setState({data})
})
.catch(err=>{
console.log(`The error is ${err}`)
})
}
render(){
return(
<div>
<Card data={this.state}/>
</div>
)
}
}
export default PropX
和卡:
/*
Card component
Reads data fetched from parent PropX
Produces Cards with sylized data
*/
import React, {Component} from 'react'
import List from '@material-ui/core/List';
import ListItem from '@material-ui/core/ListItem';
import ListItemText from '@material-ui/core/ListItemText';
import Avatar from '@material-ui/core/Avatar';
import ImageIcon from '@material-ui/icons/Image';
import WorkIcon from '@material-ui/icons/Work';
class Card extends Component{
constructor(props){
super(props)
}
render(){
return(
<ul>
{this.props.data.map(i => {
return (
<li key={i}> {i.name}</li>
)
})}
</ul>
)
}
}
export default Card
当我运行此程序时,出现以下错误:
TypeError: Cannot read property 'map' of null
Card.render
card.js:21
18 | render(){
19 | return(
20 | <ul>
> 21 | {this.props.data.map(i => {
22 | return (
23 | <li key={i}> {i.name}</li>
24 | )
删除这个
并不能解决问题。谁能告诉我这有什么问题吗?
我也尝试使用material ui(通过--save安装),但我还没有使用任何组件,因为我不明白为什么我没有数据。
最佳答案
你的问题出在 PropX 的构造函数中
constructor(props){
super(props)
state:{ // okay... so this is referenced where?
data:[{
name: 'Grrot',
city: "grav",
zip: 32453
},{
name: 'Grrot',
city: "grav",
zip: 32453
},{
name: 'Grrot',
city: "grav",
zip: 32453
}]
}
}
您需要在构造函数中将 state
分配为 this
的属性,以便稍后在传递它时,它实际上已被分配
constructor(props){
super(props)
this.state = { // now it's this.state
data:[{
name: 'Grrot',
city: "grav",
zip: 32453
},{
name: 'Grrot',
city: "grav",
zip: 32453
},{
name: 'Grrot',
city: "grav",
zip: 32453
}]
}
}
当然,现在当您在卡片中调用 .map()
时,您会收到不同的错误。您可能想要做的是将 this.state.data
传递给卡
render(){
return(
<div>
<Card data={this.state.data}/>
</div>
)
}
关于javascript - 简单的 prop 示例,但未找到 props,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50956932/
我仍在学习如何将 API 数据与 react 和 nextjs 一起使用。但是,为什么我的函数只在我编写 {props.props.title} 而不是我期望的 {props.title} 时起作用?
我仍在学习如何将 API 数据与 react 和 nextjs 一起使用。但是,为什么我的函数只在我编写 {props.props.title} 而不是我期望的 {props.title} 时起作用?
我正在用 TypeScript 构建一个 React 应用程序。我有一个 RequiresPermission基于谓词的组件应该渲染一个或另一个组件并转发所有 Prop 。 type Props =
我想通过 gatsby 布局传递我所有的 props。例如: import React, { Component } from 'react'; export default class Exampl
如果我使用合成属性,那我为什么不直接说: self.property = nil; 这将释放引用计数,并确保我没有悬挂指针。 看起来很简单,但我看到的 99% 的代码似乎都是这样做的: [proper
Eslint 抛出 eslint(react/prop-types) 错误,尽管已经声明了 propTypes。我正在使用 eslint-plugin-react 我研究了其他几个类似的问题以及 li
我正在使用以下由 linter eslint-plugin-react 解析的代码。它返回警告: "product is missing in props validation" 当我在底部的 pro
我正在尝试在 React 应用程序中添加 TypeScript。 版本: "react": "16.9.0", "typescript": "3.5.3", 我有一个像这样的数组 import aLo
我有一个组件 . 如果组件没有 this.props.children , 我想设置 Prop ariaLabel作为isRequired ,否则 in 可以是可选的。我该怎么做? ariaLabe
我应该用一个代替另一个吗?一起使用它们更好吗?谢谢。 最佳答案 prop in obj 检查 obj 是否有名为 prop 的属性,即使它只是从原型(prototype)继承而来。 obj.hasOw
我的组件 Text有 2 个 Prop :isHideable: boolean和 hidden: boolean .我如何允许 Hidden仅在 isHideable 时作为 Prop 是true
我试图将带有一些 Prop 的功能组件发送到另一个组件,并在接收组件中尝试键入检查该组件的某些 Prop 。这是代码: // BaseButton.tsx export type ButtonProp
是否可以从也作为 prop 传递的未知组件推断出正确的 props 类型? 如果已知组件(存在于当前文件中),我可以获得 Prop : type ButtonProps = React.Compone
我对 react 还很陌生,这是我正在努力解决的问题。 有一个父组件 家长 它将 Prop 传递给 child 。 其中一个 Prop ,包括一个要渲染的元素,如下所示: 在子组件中,我想获取这个组
我想做一个 Tabs推断 active 的可能值的组件prop 基于它的 child 拥有的东西 name Prop 。这就是我尝试这样做的方式: import React from 'react'
我对 react 还很陌生,并且只有当用户开始向下滚动时,我才尝试将更多信息加载到记录数组中。问题是新信息出现在数组中,但如果您尝试调用它,它将返回undefined。我在这里不明白什么? 父组件:
因此,如果我对一个组件有很多不同的 Prop ,我希望我可以做类似的事情 const { ...props } = props; 而不是 const { prop1, prop2, prop3, ..
这是我寻求指导的问题类型,因为我不确定我正在寻找的内容是否存在...... 上下文:我正在使用 Firestore 来保存数据,并且正在构建一个可重用的自定义 Hook (React 16.8),以便
我有一个 React 组件,它获取一个配置对象作为 prop,它看起来像这样: { active: true, foo: { bar: 'baz' } } 在
如何附加另一个属性?我有一个 react 组件,其中有人传入 ...props,我想附加一个额外的 Prop 最佳答案 请记住,传递 Prop 的顺序将决定将哪个值传递给该组件。这适用于有两个同名
我是一名优秀的程序员,十分优秀!