使用 RequireJs 时未从 Html 调用 Typescript 函数

Typescript function not called from Html while using RequireJs

我正在尝试使用 RequireJs 在 Html 中加载 Typescript 函数。我在类型脚本中做了一个简单的警报功能,如下所示,它似乎没有得到 called.This 应该很简单,但我尝试了所有基本检查,但不确定缺少什么。

Eventhandler.ts:

export function Main() 
{
    alert("Hi");

 }

Eventhandler.js:

define(["require", "exports"], function (require, exports) 
{
    "use strict";
    Object.defineProperty(exports, "__esModule", { value: true });
    function Main() {
        alert("Hi");
    }
    exports.Main = Main;
});

tsconfig.json:

{
  "compilerOptions": {
    "noImplicitAny": false,
    "noEmitOnError": true,
    "removeComments": true,
    "sourceMap": true,
    "module": "AMD",
    "target": "es5",
    "outDir": "../appscriptJS"
  },
  "exclude": [
    "node_modules",
    "wwwroot"
  ]
}

需要配置的主要 js 文件是 app.js。

app.ts:

/// <reference path="../scripts/typings/requirejs/require.d.ts" />
require.config(
{
    baseUrl: './appscriptJS',
    paths: { jQuery: '../scripts/jquery-3.4.1.min.js' }
});

require(['EventHandler'], function(app){ app.Main();});

各自的js文件,app.js:

define(["require", "exports"], function (require, exports) {
    "use strict";
    Object.defineProperty(exports, "__esModule", { value: true });
    function Main() {
        alert("Hi");
    }
    exports.Main = Main;
});

Html 页面: ``` 输入您的手机号码:

<div><span id="message"></span></div>
<input type="button" class="btn-default" id="submit" value="Submit" />

<script data-main="app.js" src="~/Scripts/require.js"></script>

```

修复非常简单。 require js api 中的数据主要属性不会在 requirejs 配置文件中给出的基础 url 中搜索。

所以,不得不在html的脚本中给出app js文件的完整路径如下:

<script data-main="../appscriptJS/app.js" src="~/Scripts/require.js"></script>