He creado una nueva aplicación de reacción usando create-react-app
cli. Luego agregué la 'react-redux'
biblioteca usando npm install --save react-redux
.
En package.json
tengo:
"react-redux": "^4.4.5"
Desafortunadamente, la aplicación no se compila y se queja con:
Error in ./~/react-redux/lib/utils/wrapActionCreators.js
Module not found: 'redux' in C:\Users\Salman\Desktop\Courses\Internship\React\Youtube-Front-End\node_modules\react-redux\lib\utils
@ ./~/react-redux/lib/utils/wrapActionCreators.js 6:13-29
No tengo ni idea de lo que significa.
Aquí está el contenedor completo:
import React,{Component} from 'react';
import {connect} from 'react-redux';
class BookList extends Component{
renderList(){
return this.props.books.map((book)=>{
<li key={book.title} >{book.title}</li>
});
}
render(){
return(
<div>
<ul>
{this.renderList()}
</ul>
</div>
);
}
}
function mapStateToProps(state){
return{
books:state.books
};
}
export default connect(mapStateToProps)(BookList);
Aquí está completo package.json
:
{
"name": "Youtube-Front-End",
"version": "0.1.0",
"private": true,
"devDependencies": {
"react-scripts": "0.6.1",
"webpack": "^1.13.2"
},
"dependencies": {
"react": "^15.3.2",
"react-dom": "^15.3.2",
"react-redux": "^4.4.5",
"youtube-api-search": "0.0.5"
},
"scripts": {
"start": "react-scripts start",
"build": "react-scripts build",
"test": "react-scripts test --env=jsdom",
"eject": "react-scripts eject"
}
}
reactjs
react-redux
Palanqueta
fuente
fuente
npm install --save redux
ynpm install install redux
son los mismos (--save
es la opción predeterminada) docreact-redux
utiliza internamenteAction, ActionCreator, AnyAction, Dispatch, Store
estas interfacesredux
paquete de .en el momento en que llamas
export default connect(mapStateToProps,mapDispatchToProps)(App);
react-redux
intenta hacer uso de todas estas interfaces desderedux
paquete. que no está presente en este momento.Por lo tanto, es posible que deba instalar el
react-redux
paquete junto con,redux
ya que ambos tienen dependencia.fuente
Establecer
moduleResolution
como nodo entsconfig.json
Ejemplo:
"compilerOptions": { "moduleResolution": "node" }
fuente
Puede utilizar el siguiente comando:
usando npm
usando hilo
fuente
Tuve el mismo desafío mientras trabajaba con Visual Studio Code (VSC) IDE.
import { createStore, combineReducers, applyMiddleware } from 'redux';
El paquete 'redux' se estaba resolviendo desde otro lugar todos juntos, como una dependencia dentro de algunos paquetes de mecanografiado.
Corrí
yarn add [email protected]
(con el terminal VSC) para reinstalar el paquete. Tenga en cuenta que tenía la versión exacta dentro de mipackage.json
como dependencia, y esto ayuda a Yarn a vincular las dependencias más rápido ya que mi objetivo no era actualizar redux todavía.fuente