小能豆

修改了原始代码,但执行npm run build提示错误

javascript

修改了原始代码,但执行npm run build提示错误,package.json文件中的scrips也没有build命令,想问下新版本的cesium应该怎么打包


阅读 38

收藏
2024-06-13

共1个答案

小能豆

在新版本的 Cesium 中,打包和构建流程有所改变。以下是一些步骤,帮助你解决如何在新版本的 Cesium 中进行打包和构建的问题。

1. 安装 Cesium

首先,确保你已经安装了 Cesium 库。你可以通过 npm 安装 Cesium:

npm install cesium

2. 配置 package.json

如果你的 package.json 中没有 build 脚本,你可以手动添加一个。根据项目的不同,你可能需要调整具体的脚本内容。以下是一个示例配置:

{
  "name": "your-project-name",
  "version": "1.0.0",
  "description": "Your project description",
  "main": "index.js",
  "scripts": {
    "start": "webpack serve --open --mode development",
    "build": "webpack --mode production"
  },
  "dependencies": {
    "cesium": "^1.83.0"
  },
  "devDependencies": {
    "webpack": "^5.0.0",
    "webpack-cli": "^4.0.0",
    "webpack-dev-server": "^3.11.2"
  }
}

3. 配置 Webpack

为了打包 Cesium,你需要配置 Webpack。创建或更新你的 webpack.config.js 文件,确保 Cesium 能够正确打包。以下是一个基本的 Webpack 配置示例:

const path = require('path');
const webpack = require('webpack');
const CopyWebpackPlugin = require('copy-webpack-plugin');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const { CleanWebpackPlugin } = require('clean-webpack-plugin');

module.exports = {
  context: __dirname,
  entry: './src/index.js',  // 入口文件,根据你的项目结构调整
  output: {
    path: path.resolve(__dirname, 'dist'),
    filename: 'bundle.js',
    sourcePrefix: '',
  },
  resolve: {
    alias: {
      cesium: path.resolve(__dirname, 'node_modules/cesium/Source'),
    },
  },
  amd: {
    // Enable webpack-friendly use of require in Cesium
    toUrlUndefined: true,
  },
  node: {
    // Resolve node module use of fs
    fs: 'empty',
  },
  module: {
    rules: [
      {
        test: /\.js$/,
        exclude: /node_modules/,
        use: {
          loader: 'babel-loader',
        },
      },
      {
        test: /\.(png|gif|jpg|jpeg|xml|json|svg|gltf)$/,
        use: ['url-loader'],
      },
    ],
  },
  plugins: [
    new CleanWebpackPlugin(),
    new HtmlWebpackPlugin({
      template: 'src/index.html',
    }),
    new CopyWebpackPlugin({
      patterns: [
        {
          from: path.join('node_modules', 'cesium', 'Build', 'Cesium'),
          to: 'cesium',
        },
      ],
    }),
    new webpack.DefinePlugin({
      CESIUM_BASE_URL: JSON.stringify('cesium'),
    }),
  ],
  devServer: {
    contentBase: path.join(__dirname, 'dist'),
    compress: true,
    port: 9000,
  },
};

4. 创建入口文件和 HTML 模板

创建 src/index.jssrc/index.html 文件:

src/index.js:

import { Viewer } from 'cesium';
import 'cesium/Build/Cesium/Widgets/widgets.css';

const viewer = new Viewer('cesiumContainer');

src/index.html:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Cesium App</title>
  <style>
    @import url(cesium/Widgets/widgets.css);
    html, body, #cesiumContainer {
      width: 100%;
      height: 100%;
      padding: 0;
      margin: 0;
      overflow: hidden;
    }
  </style>
</head>
<body>
  <div id="cesiumContainer"></div>
</body>
</html>

5. 打包项目

现在,你可以运行以下命令来启动开发服务器和打包你的项目:

npm run start    # 启动开发服务器
npm run build    # 构建生产版本

这些步骤应该能够帮助你在新的 Cesium 版本中正确打包和构建你的项目。如果你遇到特定的错误或问题,可以提供更多详细信息,我会进一步帮助你解决。

2024-06-13