- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
The code at this plnkr有一个模态,当用户点击 “点击参加测验” 按钮时弹出,该按钮调用 Controller 方法,而 Controller 方法又调用模态服务。 要使 plnkr 正常工作,请单击代码中的任意位置并按空格键以不影响语法的方式添加空格。这将触发 plnkr 重新初始化应用程序,并在您单击按钮后弹出模式。
问题是当 timeLeft
变量倒计时时,模式中打印的文本不会动态更新。而且,用户的按钮点击不会更新 quizAnswer
变量。简而言之,模式无法与调用 Controller 和 View 进行交互。
需要对 plnkr 进行哪些具体更改才能使模态文本显示动态倒计时,并使模态按钮更改 $scope.quizAnswer 变量的值?
另外,我一直在仔细阅读the documentation at this link .我认为答案可能与:
1.) $uibModal
的options
参数传入open(options)
包含参数scope
定义用于模态内容的父范围,以及属性 bindToController
,当设置为 true
时,将 scope
属性绑定(bind)到由 controllerAs
定义的特定 Controller 。
2.) open(options)
方法返回一个模态实例,包括close(result)
和dismiss(reason)
。
我怀疑解决方案在于这些方法和参数,但我正在寻找很好的例子,希望有经验的人能看到这个问题。
注意:这个问题的解决方案出现在已接受答案下方的评论中,尤其是指向另一个帖子的链接,该帖子包含 2 行代码,用于将模态按钮点击的结果发送回父 Controller 。
最佳答案
你有很多问题。
首先,navigation.js 的 takeQuiz
- 第 16 行,应该附加到 $scope
,而不是 this
,因为 this
会根据上下文发生变化。
其次,$scope.$apply
和 $scope.$digst();
在 navigation.js - 第 29/30 行是不必要的,因为你已经在一个消化周期。它们应该被删除,否则它们会触发错误。
最后(这是您问题的核心),您误解了在创建模态实例时如何绑定(bind)模态选项。它不是双向绑定(bind);它是从一个对象到另一个对象的单一扩展。因此,尝试绑定(bind)到选项(或创建带有 timeRemaining 的串联字符串)将不会在绑定(bind)后更新。
相反,一种可能性是在模态内部创建一个事件处理程序并在每次更新时广播,更新模态。此外,如果您将正文文本作为前置和附加文本传递,则插入时间戳值会更容易:
您需要在导航 Controller 中注入(inject)(并从中广播)$rootScope
,因为 modalService
已在作用域链中非常高的位置注册。
在每次滴答时,广播剩余时间 navigation.js:
$rootScope.$broadcast('timeRemainingTick', $scope.timeRemaining);
在您的 modalService.js 中,注册以接收 Controller 分配中的事件:
var timeRemainingUnbind = $scope.$on('timeRemainingTick', function(event, newTick) {
$scope.modalOptions.timeRemaining = newTick;
});
最后,确保通过在模态的关闭事件中调用 timeRemainingUnbind()
来解除事件绑定(bind),以防止内存泄漏:
$scope.modalOptions.ok = function (result) {
timeRemainingUnbind();
$modalInstance.close(result);
};
$scope.modalOptions.close = function (result) {
timeRemainingUnbind();
$modalInstance.dismiss('cancel');
};
查看我的工作 fork plunker here
关于javascript - modalService 无法与 Controller 和 View 对话,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36437129/
我能想到的最好的标题,但要澄清的是,情况是这样的: 我正在开发一种类似短 url 的服务,该服务允许用户使用他们的 Twitter 帐户“登录”并发布内容。现在这项服务可以包含在 Tweetdeck
我正在开发一个应用程序,我需要用户使用类似聊天的系统相互交互。 为此,我想创建一个对话模型。据我所知,我将使用多对多关系。 具有以下模型:Conversation、User 和 Message,我想象
我试图在一个页面上多次实现 jquery 对话框 - 基本上,我想在用户单击某个人的名字时显示有关该人的更多信息。 我正在使用 php 生成页面。 我尝试这样做,并使其部分工作,但我只能使页面上的第一
我制作了一个 CustomTypeDialog 类,我想要的是使用不在 Activity 布局中的 EditText。当我尝试单击其中一个按钮时出现空指针异常,我认为这是因为它们不在 Activity
我有这个程序,我想知道如何继续它。我想让用户在“发生了什么”之后输入更多文本,然后让程序响应。感谢您的帮助 int main() { cout > answer; switch(an
我目前正在开发一个由 javafx ui 支持的 java 游戏。 玩家。应该可以和npc对话,这没问题。但我想要一定的文字效果。就像在 polemon 游戏或 Undertale 中一样,文本会逐个
所以基本上我正在尝试重写一个 bash 脚本,该脚本使用对话框 --radiolist 来选择区域设置、键盘、时间。目前,标签是与本地对应的数字(我为它创建了一个哈希表)。但因为我有大约 100 个语
随着社交媒体平台的快速发展,用户对内容分享的需求不断增加,社交分享按钮在数字营销和搜索引擎优化(SEO)策略中也成为提升网站流量和内容曝光率的重要工具。此外,图片、视频和文件的传输在协同工作和朋友共享
有人可以告诉我如何使用 Watson Conversation 和其他服务(例如 Twilio)调用实时电话并进行对话吗? 我可以使用 Watson Conversation、Twilio 和 Nod
我有一个包含几个 .txt 文件的目录。让我们说 hi.txt hello.txt hello_test.txt test.txt 在 VBA 中使用文件对话框,如何过滤以在下拉列表中仅显示“*tes
我有一个 session 范围的 bean,ComponenteM,它被注入(inject)到请求范围的 bean,ComponenteC 中。 @Named @RequestScoped publi
我需要收集推文“集”,即用于我的研究的推特对话; 这些集合还需要满足以下条件 其中的推文数量,以及 参与人数。 我研究过 Twitter Streaming API、twitter-stream ge
我想在用户 Lync 客户端中打开一个新对话,其中包含预先确定的消息文本,但消息的收件人由用户选择,此过程从用户单击网站。 这可能吗? 最佳答案 这里的部分问题是,如果不知道要与谁开始对话(如果有意义
在 JBoss AS7 中工作,使用 Conversation Scope 管理浏览器选项卡中的用户交互。 我注意到我的页面附加了 ?cid 参数。这很棒 - 直到用户为页面添加书签然后尝试返回它!对
本地和远程标记以及Call-ID的组合用于识别对话。据说Call-ID是一次调用的唯一值。那么为什么 Call-ID 不单独用于识别对话呢? 最佳答案 一句话:“发夹”。 “Hairpinning”是
除了这行不通之外,这里没什么好说的,我不知道为什么。 Arduino 上的串行输出什么也没有。 C# 代码的输出变为等待响应,然后什么也没有。 当我启动 C# 程序时,Arduino 上的蓝牙卡 LE
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
目前正在开发一个应用程序,它甚至可以与 Android 2.2 一起使用,我使用支持库及其 AppCompat 主题来设计我的 UI。尽管大部分 UI 工作正常,但我有一个带有自定义布局的 Alert
我正在尝试对 MySQL 表 I 进行类似对话的输出,如下所示: Content From To Date Lorem
我已经创建了消息系统,在 messages.php 上我想显示消息对话,应该显示最后一条消息,但不知道查询,因为我是 php 新手,这里是数据库信息 table:conversation_chat
我是一名优秀的程序员,十分优秀!