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

问题描述 投票:0回答:1

我正在尝试使用RequireJs在HTML中加载Typescript函数。我在类型脚本中做了一个简单的Alert函数,如下所示,它似乎没有被调用。这应该很简单,但是我尝试了所有基本检查,但不确定丢失了什么。

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>

```
node.js angularjs typescript requirejs node-modules
1个回答
0
投票

修复非常简单。require js api中的data main属性不会在requirejs配置文件中提供的基本URL中搜索。

因此,必须在html脚本中提供应用js文件的完整路径,如下所示:

<script data-main="../appscriptJS/app.js" src="~/Scripts/require.js"></script>
© www.soinside.com 2019 - 2024. All rights reserved.