AngularJs 입력 상자 천분위 명령

10829 단어
AngularJs의 지령은 정말 유용하다. 최근에 input 상자에 천분위의 쉼표를 표시해야 하기 때문에 인터넷에서 자료를 수집하고 개량했다. 지령 코드는 다음과 같다.
(function () {
    'use strict';
    angular.module('testModule')
        .directive('formatInputValue', function ($parse) {
            return {
                link: function (scope, element, attrs, ctrl) {

                    function limit() {
                        var limitV = element[0].value;
                        limitV = limitV.replace(/[^0-9.]/g, "");
                        element[0].value = limitV;
                        $parse(attrs['ngModel']).assign(scope, limitV);
                        format();
                       
                    }

                    function limitBind() {
                        var limitV = element.context.innerHTML;
                        limitV = limitV.replace(/[^0-9.]/g, "");
                        element.context.innerHTML = limitV;
                        $parse(attrs['ngBind']).assign(scope, limitV);
                        formatBind();
                    }

                    function format() {
                        var formatV = element[0].value;
                        var array = new Array();
                        array = formatV.split(".");
                        var re = /(-?\d+)(\d{3})/;
                        while (re.test(array[0])) {
                            array[0] = array[0].replace(re, "$1,$2")
                        }
                        var returnV = array[0];
                        if (attrs.name == "oneDecimal"&&array.length>1) {

                            returnV += "." + (array[1].toString().substring(0, 1));
                        }
                        else if(attrs.name == "noDecimal")
                        {
                            //keep the no decimal value
                        }
                        else{
                        for (var i = 1; i < array.length; i++) {
                            returnV += "." + array[i];
                            }
                        }
                        element[0].value = returnV;
                        

                        if (formatV == '')
                        {
                            $parse(attrs['ngModel']).assign(scope, '');
                        }
                        else if( formatV==null)
                        {
                            $parse(attrs['ngModel']).assign(scope, null);
                        }                  
                        else if ((formatV.indexOf('.') > 0) && array.length == 2 && attrs.name != "noDecimal") {
                            if (attrs.name == "oneDecimal")
                            {
                                var formatArr = new Array();
                                formatArr= formatV.split(".");
                                formatV = formatArr[0];
                                if (formatArr.length > 1)
                                { formatV += "." + (formatArr[1].toString().substring(0, 1)); }
                            }
                           
                                $parse(attrs['ngModel']).assign(scope, formatV);
                        } 
                        else {
                            $parse(attrs['ngModel']).assign(scope, parseFloat(formatV));
                        }
                       
                    }

                    function formatBind() {
                        var formatV = element.context.innerHTML;
                        var array = new Array();
                        array = formatV.split(".");
                        var re = /(-?\d+)(\d{3})/;
                        while (re.test(array[0])) {
                            array[0] = array[0].replace(re, "$1,$2")
                        }
                        var returnV = array[0];
                        for (var i = 1; i < array.length; i++) {
                            returnV += "." + array[i];
                        }
                        element.context.innerHTML = returnV;
                        $parse(attrs['ngBind']).assign(scope, formatV);
                    }

                    if (attrs.ngModel) {
                        scope.$watch(attrs.ngModel, function () {
                            limit();
                        })

                    }
                    else {
                        scope.$watch(attrs.ngBind, function () {
                            limitBind();
                        })
                    }


                    



                }
            };
        })
}());
             //     ,              ,           
             <input class="form-control" ng-model="detail.x"  name="noDecimal" format-input-value />td> 

             //      
             <input class="form-control" ng-model="detail.x"  name="noDecimal" format-input-value />td>   

             //       
             <input class="form-control" ng-model="detail.y"  name="oneDecimal" format-input-value />td>

 
전재 대상:https://www.cnblogs.com/Aaron-Lee/p/9182344.html

좋은 웹페이지 즐겨찾기