UncaughtReference 错误:使用 webpack 后 HTMLInputElement.onclick 处未定义函数

Posted

技术标签:

【中文标题】UncaughtReference 错误:使用 webpack 后 HTMLInputElement.onclick 处未定义函数【英文标题】:UncaughtReference Error: function is not defined at HTMLInputElement.onclick after using webpack 【发布时间】:2020-05-15 20:52:28 【问题描述】:

我在捆绑后从 2 个打字稿文件生成捆绑文件不断收到错误 UncaughtReference 错误:函数未在 htmlInputElement.onclick 中定义 我不知道这意味着什么,任何人都可以帮助我。

tscode

tscode

html code

这是我的 Webpack 生成的捆绑文件

/******/ (function(modules)  // webpackBootstrap
/******/    // The module cache
/******/    var installedModules = ;
/******/
/******/    // The require function
/******/    function __webpack_require__(moduleId) 
/******/
/******/        // Check if module is in cache
/******/        if(installedModules[moduleId]) 
/******/            return installedModules[moduleId].exports;
/******/        
/******/        // Create a new module (and put it into the cache)
/******/        var module = installedModules[moduleId] = 
/******/            i: moduleId,
/******/            l: false,
/******/            exports: 
/******/        ;
/******/
/******/        // Execute the module function
/******/        modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/        // Flag the module as loaded
/******/        module.l = true;
/******/
/******/        // Return the exports of the module
/******/        return module.exports;
/******/    
/******/
/******/
/******/    // expose the modules object (__webpack_modules__)
/******/    __webpack_require__.m = modules;
/******/
/******/    // expose the module cache
/******/    __webpack_require__.c = installedModules;
/******/
/******/    // define getter function for harmony exports
/******/    __webpack_require__.d = function(exports, name, getter) 
/******/        if(!__webpack_require__.o(exports, name)) 
/******/            Object.defineProperty(exports, name,  enumerable: true, get: getter );
/******/        
/******/    ;
/******/
/******/    // define __esModule on exports
/******/    __webpack_require__.r = function(exports) 
/******/        if(typeof Symbol !== 'undefined' && Symbol.toStringTag) 
/******/            Object.defineProperty(exports, Symbol.toStringTag,  value: 'Module' );
/******/        
/******/        Object.defineProperty(exports, '__esModule',  value: true );
/******/    ;
/******/
/******/    // create a fake namespace object
/******/    // mode & 1: value is a module id, require it
/******/    // mode & 2: merge all properties of value into the ns
/******/    // mode & 4: return value when already ns object
/******/    // mode & 8|1: behave like require
/******/    __webpack_require__.t = function(value, mode) 
/******/        if(mode & 1) value = __webpack_require__(value);
/******/        if(mode & 8) return value;
/******/        if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
/******/        var ns = Object.create(null);
/******/        __webpack_require__.r(ns);
/******/        Object.defineProperty(ns, 'default',  enumerable: true, value: value );
/******/        if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key)  return value[key]; .bind(null, key));
/******/        return ns;
/******/    ;
/******/
/******/    // getDefaultExport function for compatibility with non-harmony modules
/******/    __webpack_require__.n = function(module) 
/******/        var getter = module && module.__esModule ?
/******/            function getDefault()  return module['default'];  :
/******/            function getModuleExports()  return module; ;
/******/        __webpack_require__.d(getter, 'a', getter);
/******/        return getter;
/******/    ;
/******/
/******/    // Object.prototype.hasOwnProperty.call
/******/    __webpack_require__.o = function(object, property)  return Object.prototype.hasOwnProperty.call(object, property); ;
/******/
/******/    // __webpack_public_path__
/******/    __webpack_require__.p = "";
/******/
/******/
/******/    // Load entry module and return exports
/******/    return __webpack_require__(__webpack_require__.s = "./index231.ts");
/******/ )
/************************************************************************/
/******/ (

/***/ "./index231.ts":
/*!*********************!*\
  !*** ./index231.ts ***!
  \*********************/
/*! no static exports found */
/***/ (function(module, exports) 

throw new Error("Module parse failed: Unexpected token (21:8)\nYou may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders\n| \n| export class  v \n>     con : a;\n|     constructor()\n|     ");

/***/ )

/******/ );

index231.ts 文件

import   a  from "./index";


export class  v 
    con : a;
    constructor()
    
        // super();
      this.con =  new a();
      this.con.hd();
    
    static run()
    
        console.log("donne")
    

index.ts

export default class a 

    hd()
    

        console.log("dkhg");
    


html代码

    <!DOCTYPE html>
<html lang="en">
<head>

    <title>Document</title>



    <script type="text/javascript" src="./dist/bundle.js"></script>
</head>
<body>
    <input type="submit" value = "click[enter image description here][4]" onclick="new v()" id="jg">
</body>
</html>

【问题讨论】:

请提供最小的工作示例。 如果您的问题不添加相关代码,很快就会关闭。 你还需要什么 【参考方案1】:

可能有两种方式 我认为更合适的方法是使您的变量成为您正在使用的全局变量。

即窗口。[别名] = 变量名

【讨论】:

以上是关于UncaughtReference 错误:使用 webpack 后 HTMLInputElement.onclick 处未定义函数的主要内容,如果未能解决你的问题,请参考以下文章

Visual Studio 错误:/W 需要一个参数

MySQL,混淆 w/查询/错误代码:1111。组函数的使用无效。

W/CameraBase:连接到相机时发生错误:0

w.a.UsernamePasswordAuthenticationFilter :尝试对用户进行身份验证时发生内部错误(错误 11759)

Sequelize w/Postgres 测试异步错误

uWSGI 配置错误 'core/socket.c' - w/ Django & NGINX