限制字符个数显示

  实现此功能的算法有很多,这里记录一个自己使用的:

复制代码
<!DOCTYPE html>
<html ng-app='myApp'>
    <head>
        <meta charset='utf-8'>
        <script src='angular.js'></script>
        <script src='jquery-1.11.3.js'></script>
    </head>
    <body>
        <div ng-controller='myCtrl'>
            字符串:<input ng-model="inputValue" ng-change='valueChangFnc(inputValue)' placeholder="请输入字符串"><br/>
            字节限制显示:<input ng-model="maxByte" ng-change='byteChangFnc(maxByte)'><br/>
            处理结果:{{message}}
        </div>
        <script>
            angular.module("myApp",[])
            .controller("myCtrl",function($scope){
                $scope.inputValue = "";
                $scope.maxByte = 10;
                $scope.valueChangFnc = function (inputValue){
                    if(inputValue) {
                        $scope.message = getDisplayChars(inputValue, $scope.maxByte);
                    } else {
                        $scope.inputValue = "";                        
                    }
                }
                $scope.byteChangFnc = function (maxByte) {
                    if(maxByte) {
                        $scope.message = getDisplayChars(inputValue, $scope.maxByte);
                    } else {
                        $scope.maxByte = 10;                        
                    }                    
                }
                
                function getDisplayChars(str, maxLength) {
                    //计算字节数
                    var chars = 0;
                    //存储超长时最后一位的下标
                    var sub = '';
                    for (var i = 0; i < str.length; i++) {
                        var code = str.charCodeAt(i);
                        var char = code > 255 ? 2 : 1;
                        chars += char;
                        if (chars > maxLength) {
                            sub = i;
                            break;
                        }
                    }
                    if (sub) {
                        str = (str.slice(0, sub)) + '...'
                    }
                    return str;
                }
            })
        </script>
    </body>
</html>
复制代码

 

posted @   名字不好起啊  阅读(295)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示