- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个应用程序将 ui-grid 与 cellNav 结合使用,并使用 editOnFocus=true 对某些列进行编辑。我遇到的问题是编辑功能中的 END_CELL_EDIT 和 CANCEL_CELL_EDIT 总是调用 gridCtrl.focus()。如果我有一个可编辑的单元格,然后单击网格外的输入,它会窃取焦点并将其放回网格中。
发生的事情是我点击了网格外的输入。它获得焦点。同时触发 END_CELL_EDIT 事件。然后调用 gridCtrl.focus() 并将焦点从外部输入框移开。
有没有办法在 ui-grid.edit 中覆盖此行为?为什么这种行为标准?
这里有一个plnkr来演示。如果您单击年龄列使其进入编辑模式,然后单击文本区域,您将看到它暂时获得焦点并有一个光标,但很快网格就会夺回焦点,您将无法再编辑。
http://plnkr.co/edit/Sg1dTcsMN0zNRDmauwoT
这种行为对我的情况来说并不理想,因为无论何时选择或导航到该行,我们都会自动关注特定的单元格(进入编辑模式)。因此,任何更改行或将焦点移出网格的操作都会触发 END_CELL_EDIT 事件和上述焦点行为。
最佳答案
诀窍是设置另一个焦点,但将其延迟一个摘要周期 - 从而允许网格执行其需要的操作。下面是您更新后的 Plunker 中的相关代码片段。
HTML(用于绑定(bind)):
<textarea id="textarea" ng-focus="delayFocus()"></textarea>
Controller (允许摘要循环):
$scope.delayFocus = function() {
$timeout(function() {
focus('textarea');
$scope.gridApi.grid.cellNav.clearFocus();
});
}
工厂(用于重新聚焦):
app.factory('focus', function($timeout, $window) {
return function(id) {
// timeout makes sure that it is invoked after any other event has been triggered.
// e.g. click events that need to run before the focus or
// inputs elements that are in a disabled state but are enabled when those events
// are triggered.
$timeout(function() {
var element = $window.document.getElementById(id);
if (element)
element.focus();
});
};
});
更新 Plunker,http://plnkr.co/edit/UX8tbVwi9gG4zsMRG0kV?p=preview .
您可能可以将以上内容组合成一个指令,然后将其应用于所需的控件 - 如果需要/需要,我们很乐意提供帮助。
希望这能让您有个好的开始。
关于javascript - 使用 CellNav + Edit 会导致网格从网格外部的输入中窃取焦点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42928089/
我有 Site {{$url}} 和 $(function(){ $('#pencil').click
我在每一行都有一个编辑按钮,我已经设置了 defaultColDef: { editable: false, } 在网格选项中 当我点击编辑按钮时,我希望该行处于编辑模式。如果我设置
我在每一行都有一个编辑按钮,我已经设置了 defaultColDef: { editable: false, } 在网格选项中 当我点击编辑按钮时,我希望该行处于编辑模式。如果我设置
我有一个 html 文件,我想编辑其中的字段。以下是我的 html 代码: ID GROUP NAME GROUP DESCRIPTION IS A
我希望管理员能够编辑普通用户无法编辑的字段。例如作者或订阅者等。 我试过这个:Django admin: How to display a field that is marked as editab
如何将PS文件中间的数据移动到Mainframe的左侧?有什么快捷命令吗? 我有一个数据集,第 13 列有数据,必须将其移动到第 11 列,任何短键都可以移动它。 想要将 DS 中的其余行作为第一行对
我在 div 中有一个可编辑元素,它本身是可点击的。每当我单击 x-editable anchor 元素时,单击会在 DOM 中冒泡并触发对父 div 的单击。我怎样才能防止这种情况发生?我知道可以使
我有一个类似这样的模型: class Product(models.Model): third_party_id = models.CharField(max_length=64, blank
我有一个包含 2 个可编辑文本字段的页面 {{creator.name}} Tell us about yourself in less than 100 words
这是我的架构: id: 'EntryCode', fields: { EntryCode: {editable: true, validation: {required: true}, nul
有人可以帮助确定这个问题 - http://jsfiddle.net/xBB5x/8823/ 我正在尝试实现 x-editable (bootstrap 2) typeahead 功能。 上面的 js
如果我使用例如 g_object_set (renderer, "background", "red", "background-set", FALSE, NULL); 对于文本渲染器, TreeVi
我在创建和编辑页面上都使用了 Angular 文件,但我想知道是否有办法阻止用户在/edit 页面上编辑 Geo Segment 的名称。 geo-region-detail.html: G
我正在尝试向 QListWidget 添加一个项目,选择该项目,然后开始编辑新项目。 该项目被添加,它被选中,但该行没有被引入 QLineEdit,或者它试图使用的任何东西。 这是我的小部件的代码,相
我有一个表格,其中的单元格和列中有多个值。当用户单击 TD 单元格上的任意位置时,我希望它: 成为文本区域 将当前文本粘贴到文本区域 在其下方放置一个取消按钮 一旦按下取消按钮,我希望一切都变回以前的
在我的程序中,会有一个机会编辑框,它可以更改“掉率”或“获胜率” 但我想将其更改为如果用户输入大于 100 的数字并点击编辑框,编辑框文本将变回 100。 我不知道如何实现这个。 最佳答案 看看下面的
我想创建我的编辑表单,以便它将当前用户信息简单地显示为文本,而不是在文本字段中,当用户单击文本时,它将变成文本字段,用户可以编辑他的信息。仅当用户单击提交按钮时,更改才会反射(reflect)在数据库
我有一个 QTreeWidgetItem 添加到 QTreeWidget: QTreeWidgetItem* item = new QTreeWidgetItem(ui->trwPairs); ite
我检查了最新的 Dropbox 和 Excel for iOS。在 Dropbox 中,我们有一个编辑按钮。单击它会打开 Excel 的扩展程序,您可以在其中编辑文件。 保存后,更改也会反射(refl
我目前正在使用pycord创建一个Python语言的不和谐机器人。我有一个发送消息的命令,其中嵌入了两个字段。一个名为Yes,值为0;另一个名为No,值也为0。在选择菜单中,我创建了两个选项。选项是和
我是一名优秀的程序员,十分优秀!