我向NPM发布了一个React组件,当试图在另一个项目中使用它时,我找不到该模块!
Module not found: Can't resolve 'react-subreddit-posts' in '/Users/kyle.calica/Code/exmaple/app/src'
我在创建Webpack包时遇到麻烦,该包可以在开发时从中导入。我相信这是因为我正在制作ES6类符号,但是试图进行编译以便可以导入?我能够“修复”它。但是现在我在使用它时遇到了麻烦。
这是我的React组件的webpack.prod.config.js
const path = require("path");
module.exports = {
mode: 'production',
entry: path.join(__dirname, "src/index.js"),
output: {
path: path.resolve(__dirname, 'build'),
filename: 'index.js',
libraryTarget: "commonjs2"
},
module: {
rules: [
{
test: /\.(js|jsx)$/,
exclude: /node_modules/,
use: [
{
loader: "babel-loader",
options: {
presets: ["react"],
plugins: ["transform-class-properties"]
}
}
]
},
{
test: /\.css$/,
use: ["style-loader", "css-loader"]
}
]
},
resolve: {
extensions: [".js", ".jsx"]
}
};
这是我的组件入口JS文件,index.js
是如何在React组件中创建类的一个很好的例子:
import React, { Component } from 'react';
import ListContainer from './ListContainer';
import ListItemComponent from './ListItemComponent';
const redditAPI = 'https://www.reddit.com/r/';
export default class SubredditPosts extends Component {
constructor(props) {
super(props);
this.state = {
redditPosts: [],
isLoading: true
};
}
componentDidMount() {
const uri = `${redditAPI}${this.props.subreddit}.json`;
fetch(uri)
.then(data => data.json())
.then(this.handlePosts)
.catch(err => console.error(err));
}
handlePosts = (posts) => {
const apiPosts = posts.data.children.map((post, index) => {
return {
key: index,
title: post.data.title,
media: this.getMediaFromPost(post),
link: post.data.url
};
});
this.setState({
redditPosts: apiPosts,
isLoading: false
});
}
getMediaFromPost = (post) => {
const extension = post.data.url.split('.').pop();
if (post.data.hasOwnProperty('preview') && !extension.includes('gif')) {
return post.data.preview.images[0].source.url;
}
//do not use includes! because of Imgur's gifv links are not embeddable
if (extension === 'gif' || extension.includes('jpg') || extension.includes('jpeg')) {
return post.data.url;
}
//if can't load media then place placeholder
return this.props.placeholder;
}
render() {
return(
<ListContainer display={this.props.display}>
{ !this.state.isLoading && this.state.redditPosts.map(post => (
<ListItemComponent
display={this.props.display}
key={post.key}
link={post.link}
media={post.media}
title={post.title}
height={this.props.height}
width={this.props.width}
/>
))}
</ListContainer>
);
}
}
这是我项目中的App.js
,试图使用从NPM中提取的已发布的React组件:
import React, { Component } from 'react';
import SubredditPosts from 'react-subreddit-posts';
import logo from './logo.svg';
import './App.css';
class App extends Component {
render() {
return (
<div className="App">
<header className="App-header">
<img src={logo} className="App-logo" alt="logo" />
<p>
Edit <code>src/App.js</code> and save to reload.
</p>
<a
className="App-link"
href="https://reactjs.org"
target="_blank"
rel="noopener noreferrer"
>
Learn React
</a>
</header>
<div class="row">
<SubredditPosts
subreddit="aww"
display="tile"
placeholder="some_link_image_url_OR_image_path"
width="250px"
height="250px"
/>
</div>
</div>
);
}
}
export default App;
React组件的捆绑和导出我在做什么错? 还是我导入错误?
答案 0 :(得分:1)
仅安装了您的软件包,结果发现它是一个不好的发布。
从node_modules导入软件包时,node / webpack会找到目录,读取其中的package.json文件,然后导入package.json中由main
字段指示的文件。如果这些步骤中的任何一个失败,则导入将无法解决。
您的package.json说"main": "dist/index.js"
,但发行版中没有dist目录,只有lib目录。
将字段更改为"main": "lib/index.js"
可能会起作用,但是还有其他问题。您的依赖关系无处不在。 devDependencies
是仅由开发人员使用的软件包。它用于构建工具,测试工具,棉绒等。dependencies
是使软件包正常工作所必需的。区别在于安装软件包时将安装依赖项的dependnecies
,而不会安装依赖项的devDependencies
。
在您的情况下,您需要dependencies
中的react和react-dom以及devDependnecies
中的其他所有内容。另外,npm始终安装在全球范围内,而您的package.json中根本不需要它。
我建议您查阅一份指南,以维护开源软件包和/或检查如何设置现有软件包。理解起来并不难,但是您应该知道很多事情,您在开发应用程序时并不关心。