gpt4 book ai didi

javascript - 温泉 [ng :areq] Argument '' is not a function, 未定义

转载 作者:行者123 更新时间:2023-12-03 07:12:16 25 4
gpt4 key购买 nike

我知道这个问题被问了大约一百次。我尝试了很多解决方案。遗憾的是没有一个对我有用。

我正在使用 Onsen 和 AngularJS 进行编程。

HTML:

    <ons-template id="signin.html">
<ons-dialog var="dialog">
<ons-toolbar>
<div class="center">Log In</div>
</ons-toolbar>

<div class="login-form" ng-app="SignIn" ng-controller="SignCtrl">
<input type="email" class="text-input--underbar" placeholder="Email" value="">
<input type="password" class="text-input--underbar" placeholder="Password" value="">
<br><br>
<ons-button modifier="large" class="login-button">Log In</ons-button>
<br>
<ons-button modifier="quiet" class="forgot-password">Forgot password?</ons-button>
<ons-button modifier="quiet" class="forgot-password" ng-click="showSignUp()">Not a member?</ons-button>
</div>

</ons-dialog>
</ons-template>

Javascipt (js/signctrl.js):

(function(angular){
// init functions
'use strict';

var app = angular.module('SignIn', []);
app.controller('SignCtrl', function($scope) {
$scope.showSignUp = function() {
alert("foo!");
ons.createDialog('signup.html').then(function(dialog) { dialog.show(); });
};
});

})(window.angular);

以及包含的文件:

<script src="components/loader.js"></script>
<link rel="stylesheet" href="components/loader.css">
<link rel="stylesheet" href="css/style.css">
<link rel="stylesheet" href="css/signin.css">
<link rel="stylesheet" href="css/signup.css">
<link rel="stylesheet" href="css/locations.css">

<link rel="stylesheet" href="lib/onsen/css/onsenui.css">
<link rel="stylesheet" href="components/monaca-onsenui/css/onsen-css-components-sunshine-theme.css">
<script src="lib/onsen/js/angular/angular.js"></script>
<script src="lib/onsen/js/onsenui.js"></script>
<script src="js/signctrl.js"></script>

并且 ons.bootstrap() 在开始时被调用(在包含 js/signctrl.js 之前)。

如果您能帮助我,我将非常高兴并感谢您的帮助。

PS:完整错误为[ng:areq] Argument 'SignCtrl' is not a function, got undefined

PPS:真正的完整错误:

Error: [ng:areq] Argument 'SignCtrl' is not a function, got undefined
http://errors.angularjs.org/1.4.3/ng/areq?p0=SignCtrl&p1=not%20a%20function%2C%20got%20undefined
at file:///data/data/mobi.monaca.debugger/files/projects/cloud/570c898afd17349b6c3d57a4/www/components/loader.js:1460:4931
at assertArg (file:///data/data/mobi.monaca.debugger/files/projects/cloud/570c898afd17349b6c3d57a4/www/components/loader.js:1460:18360)
at assertArgFn (file:///data/data/mobi.monaca.debugger/files/projects/cloud/570c898afd17349b6c3d57a4/www/components/loader.js:1460:18562)
at file:///data/data/mobi.monaca.debugger/files/projects/cloud/570c898afd17349b6c3d57a4/www/components/loader.js:1462:20613
at setupControllers (file:///data/data/mobi.monaca.debugger/files/projects/cloud/570c898afd17349b6c3d57a4/www/components/loader.js:1461:27741)
at nodeLinkFn (file:///data/data/mobi.monaca.debugger/files/projects/cloud/570c898afd17349b6c3d57a4/www/components/loader.js:1461:28989)
at compositeLinkFn (file:///data/data/mobi.monaca.debugger/files/projects/cloud/570c898afd17349b6c3d57a4/www/components/loader.js:1461:21271)
at file:///data/data/mobi.monaca.debugger/files/projects/cloud/570c898afd17349b6c3d57a4/www/components/loader.js:1461:19821
at pre (file:///data/data/mobi.monaca.debugger/files/projects/cloud/570c898afd17349b6c3d57a4/www/components/loader.js:1474:25379)
at invokeLinkFn (file:///data/data/mobi.monaca.debugger/files/projects/cloud/570c898afd17349b6c3d57a4/www/components/loader.js:1462:13182)

最佳答案

这可能是一个时间问题。它尝试在包含 Controller 的元素初始化之前访问 Controller 。要解决这个问题,请将您的 Angular 代码包装在 ons.ready 函数 ( see the docs ) 上,一旦 onsen 完全加载,该函数就会执行您的代码。

例如:

ons.ready(function() {

//Your angular code

})

此外,您似乎忘记将温泉模块添加到 Controller 中。

希望它能解决您的问题!

关于javascript - 温泉 [ng :areq] Argument '' is not a function, 未定义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36583990/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com