Angular.js 内联编辑

Posted

技术标签:

【中文标题】Angular.js 内联编辑【英文标题】:Angular.js inline-editing 【发布时间】:2013-03-24 23:40:18 【问题描述】:

我正在尝试找到使用 angularjs 进行内联编辑的最佳方法。就我而言,它是一种带有“编辑”按钮的数据网格。所以它在 ng-repeat 里面。

我看到人们所做的是将实际数据和编辑输入放在同一行中,编辑输入被隐藏并在单击编辑按钮时显示。

但这似乎不对。在我看来,这是很多无用的 DOM。

所以我想我会更好地做这样的事情。您单击编辑按钮,它将有一个指令,它将 1) 隐藏带有数据的 <td> 2) 找到按钮的父级,应该是 <tr>,并在其中注入一个模板 3) on保存删除那些编辑<td>s 并再次显示数据<td>s。

所以我开始制作指令,里面有 element.click() 函数,它

// found the parent
var parent = element.closest('tr');
// found all the data tds
var tds = parent.find('td');
// hidden them  
tds.hide();

现在问题来了,接下来我想做这样的事情

// append input with editing tds into parent
parent.append('<td><input type="text" ng-model="entry.name" /> entry.name </td>');

但是它不会绑定甚至解析 吗?我必须使用什么方法而不是 jquery 的追加?

关于指令的文档是这样说的

模板元素 - 声明指令的元素。 对元素和子元素进行模板转换是安全的 仅元素。

所以我不能在 element.parent() 上使用模板转换

如果我在&lt;tr&gt; 上制定指令会有帮助吗?即使我这样做了,我也会转换我的整个&lt;tr&gt;,这意味着我丢失了原始模板,我必须有另一个指令或将其转换回原始状态的东西..不是吗?

编辑

因为这个问题似乎很受欢迎.. 首先我最初担心每次 ng-repeat 迭代渲染额外元素是没有根据的,因为 1) 你可以使用 ng-if,这意味着它不会被渲染,直到条件满足真的 2) 你可以按照我的意图附加一个模板,然后只需使用 $compile 就可以了,它肯定不会“昂贵”,因为你只是为了一个元素。有很多方法可以解决这个问题,但 ng-if 是最简单的,如果 supermasher 的方法不适合你,那就是。

【问题讨论】:

【参考方案1】:

注入新模板是一种相当昂贵的处理方式,尤其是当您的内联编辑器实例很多时。

有很多方法可以做到这一点,但最简洁(也是最简单)的是使用相同的元素来编辑和显示您的数据,然后使用指令简单地切换它的 CSS 以更改它在两种状态下的显示方式,例如所以:

myApp.directive('inlineEdit', function () 

return function (scope, element, attrs) 
    element.bind('click', function () 

        if (element.hasClass('inactive')) 
            element.removeClass('inactive');
         else 
            element.addClass('inactive');
            $(element).blur()
        
    );
;

);

查看这个小提琴以获得完整的工作示例:http://jsfiddle.net/3EaY8/。

【讨论】:

..禁用我的意思是让它看起来不是css的输入 在 CSS 浏览器支持方面,我认为您对这种方法没有任何重大问题。就您的插件而言,这似乎是您不想每次都更改 DOM 的另一个原因,因为您肯定也必须重新绑定您的插件。 是的,但是 a) 我必须让我的所有插件 not 在类处于非活动状态时接受点击 b) 像 select2 这样的插件实际上隐藏了原始输入,并附加自己的 div,所以这并不容易。 悬而未决的问题实际上集中在原始问题中未说明的问题上。我建议您接受我的回答,因为它是您原始问题的一个很好的解决方案,并且可能对其他人有用,然后提出一个新问题,包括您的附加插件要求。理想情况下,您还应该尽可能提供小提琴以增加获得答案的机会。 我已经在 SO 上查看了其中的几个,这个是我最喜欢的。谢谢!【参考方案2】:

只要把它扔在那里,如果你使用新的ng-if 指令来“隐藏”那些编辑输入和东西,“很多无用的 DOM”就不再是什么问题了,因为 ng-if 没有根本不渲染 html

【讨论】:

【参考方案3】:

您好,我知道已经有一个公认的答案,但我偶然发现了这个

http://vitalets.github.io/angular-xeditable/

最近,我相信这是一个非常体面的项目,可以处理一般的可编辑控件。

希望对某人有所帮助。

【讨论】:

以上是关于Angular.js 内联编辑的主要内容,如果未能解决你的问题,请参考以下文章

Angular JS:具有绑定值的内联样式适用于 Mac 而不是 Windows

html Angular:JS Quill的WYSIWYG编辑器

在Angular js的编辑案例中没有得到文本更改值

Angular js中的内容可编辑

Angular JS在textarea中显示和编辑模型

angular.js解决textarea前端编辑保存,需要转换的问题