首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >修改ng绑定和添加省略的AngularJS指令

修改ng绑定和添加省略的AngularJS指令
EN

Stack Overflow用户
提问于 2013-07-31 20:15:32
回答 2查看 5.4K关注 0票数 1

我做了一个AngularJS指令,添加一个省略号以溢出:隐藏文本。它似乎在Firefox中不起作用,而且我也不相信我已经尽可能地构造了它。流动情况如下:

  1. 向HTML元素添加指令属性
  2. 指令将ng-bind属性读入范围。
  3. 指令监视在链接函数中对ng-bind的更改。
  4. 对于ng-bind更改,指令会进行一些复杂的计算,以确定应该在什么地方拆分文本并添加省略号(我这里没有包含这段代码,只是假设它能工作)
  5. 指令将元素的HTML设置为此新字符串,而不是接触ng-绑定。

代码语言:javascript
复制
<p data-ng-bind="articleText" data-add-ellipsis></p>

指令

代码语言:javascript
复制
app.directive('addEllipsis', function(){
    return {
        restrict    : 'A',
        scope       : {
            ngBind    : '='  // Full-length original string
        },
        link        : function(scope, element, attrs){
            var newValue;

            scope.$watch('ngBind', function () {
                /*
                 *  CODE REMOVED - Build shortened string and set to: newText
                 */

                 element.html(newText);  // - Does not work in Firefox and is probably not best practice
            });
        }
    };
});

问题的最后一行是指令中的最后一行:

代码语言:javascript
复制
 element.html(newText)

我假设应该使用模板风格的方法?我不清楚如何最好地解决这个问题。谢谢你的帮助。

EN

回答 2

Stack Overflow用户

发布于 2013-07-31 22:05:02

你可以用过滤器代替。就像这样:

滤波器

代码语言:javascript
复制
app.filter('addEllipsis', function () {
    return function (input, scope) {
        if (input) {
            // Replace this with the real implementation
            return input.substring(0, 5) + '...';  
        }
    }
});

代码语言:javascript
复制
<p data-ng-bind="articleText | addEllipsis"></p>
票数 10
EN

Stack Overflow用户

发布于 2013-07-31 21:19:31

如果你用data-ng-bind="articleText"代替ng-model="articleText",它应该在Chrome和火狐中都能工作。我不知道为什么,也许是虫子?但这是一个快速的解决办法。

如果您对这种差异感兴趣,可以查看这个帖子。但是在不同的浏览器中不同的行为确实有点奇怪。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17980078

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档