- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
tl;博士;
似乎无法嵌入类似 ng-messages 指令。当您嵌入它时,它无法正确绑定(bind)。我有 2 个解决方法,但都有其缺点。有人有更好的解决方案还是我做错了什么?
我正在使用 typescript 。
版本
AngularJS:1.6.1
Angular 动画:1.6.1
Angular 咏叹调:1.6.1
Angular 消息:1.6.1
Angular Material :1.1.0
typescript :3.10.5
我要什么
我有一个格式化日期的组件(做了更多,但这不相关)并显示它。其中一些组件包含在同一页面上。围绕这些组件的是一种形式。我想使用自定义 ng-messages 验证此表单,例如当日期在将来时会显示错误消息。
有什么问题
当我将自定义错误消息嵌入到组件时,绑定(bind)失败。有一个错误(Angular-material 在输入字段下显示一条红线)但属于该错误的消息未显示。
它什么时候起作用?
当我不包含 ng-messages,而是将它们与组件的 html 内联时,会显示错误消息。这里唯一的问题是表单名和输入名是动态的(通过组件绑定(bind)定义)所以我需要使用 this.$eval($ctrl.inputName+'Form.'+$ctrl.inputName)['$error']
,我真的不想使用(来自 GitHub AngularJS issues )。
它看起来怎样?
在 WorkHoursController 中,我检查日期的有效性。如果一个无效,我设置 $setValidity
从那里的子表单的输入字段。这就是我使用动态表单和表单项名称的原因(还有超过 1 个 datepicker.html 嵌入到 workhours.html,因此我不能使用静态名称)。
我想要的(但不起作用)
将整个 ng-message div 嵌入到组件中,不带 this.$eval()
工作时间.html
<div layout="column" layout-fill ng-cloak>
<md-content>
<form name="bigForm" novalidate>
<div class="formCard md-whiteframe-2dp">
<h4>Workhours</h4>
<date-picker title="Select workhours"
model="$ctrl.time.workhour"
input-name="workhour">
<div ng-messages="workhourForm.workhour.$error">
<div ng-message="inFuture">You cannot plan workhours in the future</div>
</div>
</date-picker>
</div>
</form>
</md-content>
</div>
日期选择器.html
<ng-form name="{{$ctrl.inputName}}Form">
<md-input-container class="md-block" ng-click="$ctrl.showPicker()">
<input ng-model="$ctrl.formattedModel"
aria-label="Open dateTimePicker"
name="{{$ctrl.inputName}}"
readonly
ng-transclude>
</md-input-container>
</ng-form>
以这种方式执行此操作时,将不会显示错误消息。只有红线。所以嵌入有问题。
<ng-form name="{{$ctrl.inputName}}Form">
<md-input-container class="md-block" ng-click="$ctrl.showPicker()">
<input ng-model="$ctrl.formattedModel"
aria-label="Open dateTimePicker"
name="{{$ctrl.inputName}}"
readonly>
<div ng-messages="this.$eval($ctrl.inputName+'Form.'+$ctrl.inputName)['$error']">
<div ng-message="inFuture">You cannot plan workhours in the future</div>
</div>
</md-input-container>
</ng-form>
这样,所有消息都在 Datepicker.html 中定义。因此,我无法添加任何自定义消息,只能使用预定义消息。这不是我想要的,因为这个组件可以在多种情况下使用,每种情况都有自己的业务规则。
<ng-form name="{{$ctrl.inputName}}Form">
<md-input-container class="md-block" ng-click="$ctrl.showPicker()">
<input ng-model="$ctrl.formattedModel"
aria-label="Open dateTimePicker"
name="{{$ctrl.inputName}}"
readonly>
<div ng-messages="this.$eval($ctrl.inputName+'Form.'+$ctrl.inputName)['$error']" ng-transclude>
</div>
</md-input-container>
</ng-form>
工作时间.html
<div layout="column" layout-fill ng-cloak>
<md-content>
<form name="bigForm" novalidate>
<div class="formCard md-whiteframe-2dp">
<h4>workhours</h4>
<date-picker title="Select workhours"
model="$ctrl.time.workhours"
input-name="workhours">
<div ng-message="inFuture">You cannot plan workhours in the future</div>
</date-picker>
</div>
</form>
</md-content>
</div>
使用此选项,ng-messages 是动态的,可以添加任何您想要的内容。但是类
md-input-message-animation
不添加。什么导致大文本和错误消息没有动画。可以手动添加这个类,但是在嵌入中出现了问题。
this.$eval($ctrl.inputName+'Form.'+$ctrl.inputName)['$error']
的使用并且仍然使代码与动态表单和表单域名称一起工作? 最佳答案
在阅读了其他一些帖子并尝试了很多东西之后,我找到了问题的答案。
问题1的解答
这是 Material 设计中的问题。我可以用 $postLink
来解决这个问题在我的日期选择器组件中起作用。然而这个问题不是这个组件的责任。因此,一个也符合面向对象准则的解决方案我需要制定一个指令,将缺少的类添加到每个嵌入的元素。
指令(custom-ng-message)
class CustomNgMessageLinkController {
constructor(scope: ng.IScope, element: ng.IAugmentedJQuery, attrs: ng.IAttributes) {
element.addClass('md-input-message-animation');
}
}
function CustomNgMessageDirective(): ng.IDirective {
return {
restrict: 'A',
scope: {},
link: CustomNgMessageLinkController
};
}
使用此指令,我可以执行以下操作:
<div custom-ng-message ng-message="inFuture">You cannot plan workhours in the future</div>
这将转化为预期结果:
formName
),在 Controller 中创建表单名称(而不是像我以前那样在 HTML 中)并在返回字段的 Controller 中添加额外的函数(一个对象
ng.INgModelController
)。
constructor(private $scope: ng.IScope) {
this.formName = this.inputName + 'Form';
}
日期选择器组件中的新方法:
/**
* Gets the form of the scope and returns the input field
* @return {ng.INgModelController}
*/
getFormInput(): ng.INgModelController {
let formName = this.inputName + 'Form';
return this.$scope[formName][this.inputName];
}
此方法与
this.$eval
几乎相同。 .唯一的区别是它不会造成安全问题。
formName
在 HTML 中像这样:
<ng-form name="{{$ctrl.formName}}">
<md-input-container class="md-block" ng-click="$ctrl.showPicker()">
<input ng-model="$ctrl.formattedModel"
aria-label="Open dateTimePicker"
name="{{$ctrl.inputName}}"
readonly>
<div ng-messages="$ctrl.getFormInput().$error" ng-transclude>
</div>
</md-input-container>
</ng-form>
这允许我使用动态表单和输入名称。这很有用,因为我在一页上有多个此组件。
MomentJS
日期并设置错误消息,如下所示:
constructor($scope: IWorkHourScope) {
$scope.$watch(() => {
return this.time.workhour;
}, (newValue: Moment, oldValue: Moment) => {
if (newValue > moment()) {
$scope.timeSheetForm.workHourForm.workhour.$setValidity('inFuture', false);
}
});
}
这也使得为我的表单项创建所需的接口(interface)变得更加容易,因为所有表单都有不同的名称,我可以为每个子表单分配正确的属性。
interface IWorkDateForm {
workhour: ng.INgModelController;
}
interface IIllNessDateForm {
illness: ng.INgModelController;
}
interface ITimeForm extends ng.IFormController {
workhourForm: IWorkDateForm;
illNessForm: IIllNessDateForm;
}
interface ITimeSheetScope extends ng.IScope {
timeForm: ITimeForm;
}
这样我就不必使用 '
any
' 对于我的表单,我可以从 AngularJS 库中自动完成。
关于javascript - Ng-messages 动态表单和输入名称,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41716776/
我尝试将 python 2.x 代码移植到 python 3。我正在努力解决的问题是 from mimetools import Message ... headers = Message(Strin
我有一个输入组件,它有三种类型的验证(required、validatorMessage、converterMessage),这个输入有自己的消息图标,整个表单有一个消息组件来显示所有组件的所有消息,
我有一个使用消息代理 (activemq) 的带有 spring 和 websockets 的 webapp。 这是我的配置类: @Configuration @EnableWebSocketMess
据我了解mbox Python 3.6 标准库中的类生成 email.message.Message 类型的旧式消息对象. 较新的类(class) email.message.EmailMessage
我使用的是mysql。 我有一个包含 userid、message_id、opened(true 或 false)、时间戳的消息表。 我希望所有未打开最近收到的 5 条消息的用户 这就是我现在拥有的:
我是 Android 的新手,发现要不断更新主视图,我必须创建一个线程来处理各种进程,然后将更新传回主视图。我决定使用 Handler 类来执行此操作。此示例中的 View 有一个用于激活代码的按钮和
我遇到了重定向符号的不同位置( > , &2 message message echo message >&2 message >&2 echo message message 对于所有表单,我得到了
我想使用 firebase 云函数发送通知,所以我尝试使用 firebase.messaging().getToken() 获取 token ,但我不断收到错误消息: TypeError: fireb
我实现了一个短信应用。现在我在使用 Oppo 设备时遇到了问题,因为无论何时收到消息,系统都会将默认应用程序更改为内置应用程序并显示此消息: For your messages security, S
我正在实现本指南:https://spring.io/guides/gs/centralized-configuration/关于Spring Cloud配置。 服务器: @EnableConfigS
我想在“匹配”之后,向所有比赛发送介绍信息。你知道一种轻松发送的方法吗?(我使用 Bluestacks) 提前致谢。问候。 最佳答案 只需传递 session.send()在session.dialo
在我们的应用程序中,我们使用 kafka 并有一个像这样的 Spring Cloud 输入流 @Component public interface SomeChannel { @Input(
这周我在通过 Node.js 库(代码相同,库版本相同等)向我的 iOS 设备发送消息时遇到了很多内部错误 很难调试,因为有时它会起作用。当我使用 for 循环发送 10 条消息时,我的设备将收到 3
我目前正在记录错误并希望获得尽可能多的描述性细节。我知道我可以捕获许多不同类型的异常,但 Exception.Message 之间有什么区别?和 Exception.InnerException.Me
我创建了一个映射到 MyBean.beansField 的表单。我使用 javax.validation.NotNull 注释来确保必须输入它。到目前为止一切正常,但错误消息如下所示: beansFi
我正在研究 Azure 服务总线。我的服务总线队列正在处理一条消息 3 次。我的消息锁定时间是5分钟。每条消息最多处理 2 分钟,但我不知道为什么队列会选择相同的消息并发送到处理,而重复的消息仅在 5
我正在使用最新的快速修复版本,即 1.6.0。我已经有针对 1.5.3 编写的代码,我想做的是将其升级到 1.6.0 我遇到的问题是,当我使用破解(msg,sessionID)方法时,它会抛出quic
当我调用 grails message()函数来查找和评估消息 key 对,它无法评估参数。 在我的 Controller 中,我调用消息函数: rejectWithError(message(cod
我使用一个小型 Spring 应用程序,其中数据库中的值很少,我想使用可变调用来检索它们。 API 在这里, @RestController @RequestMapping("/api/v1/prod
我在想在用以更好的方式,像这样: Please inform us about: 这个想法是以一种不同的方式向用户展示消息,具有更多的风格。这可能吗? 最佳答案 它们可通过 Fac
我是一名优秀的程序员,十分优秀!