实用的JS代码段(表单篇)

简介:

整理了下比较实用的Javascript代码段,完整的代码参考

1 多个window.onload方法

  由于onload方法时在页面加载完成后,自动调用的。因此被广泛的使用,但是弊端是只能实用onload执行一个方法。下面代码段,可以保证多个方法在Onload时执行:

复制代码
    function addLoadEvent(func){
        var oldonload = window.onload;
        if(typeof window.onload != 'function'){
            window.onload = func;
        }else{
            window.onload = function(){
                oldonload();
                func();
            }
        }
    }
复制代码

2 正则表达式去空格

str.replace(/^(\s|\u00A0)+|(\s|\u00A0)+$/g,"");

3 利用正则过滤中文

str.replace(/[\u4e00-\u9fa5]/g,"");

4 禁止用户的拷贝和复制

复制代码
xxx.oncopy = function(){
    return false;
}
xxx.onpaste = function(){
    return false;
}
复制代码

5 限制字符串长度(区分中英文)

  主要思想:

  需要3个数据:1 限制输入的长度;2 已经输入了多长; 3 截取多少个字符;

  由于JS里面的截取方法不区分中英文 ,因此

  “哈哈哈”.substr(0,2) ----> 哈哈

  “haha”.substr(0,2) ---> ha

  但是,如果按照编码一个汉字应该对应2个字符,一个字母对应一个字符。

  因此统计 真实长度 时,应该是 字符的长度 汉字的个数 

  例如我们限制输入5个字符:那么输入“哈哈”后,就只能输入一个h,不能再输入汉字了。代码参考如下,可以运行一下推敲推敲。 

复制代码
    <script type="text/javascript">
        var strLen = (function(){//strlLength的功能相同,但是写法巨麻烦
            return function(_str,_model){
                _model = _model || "Ch"; //En模式下,中文算作1字符;Ch模式下,中文为2个字符
                var _strLen = _str.length; //获取字符串长度
                if(_strLen == 0){
                    return 0;
                }else{
                    var chinese = _str.match(/[\u4e00-\u9fa5]/g); //匹配中文
                    return _strLen + (chinese && _model == "Ch"?chinese.length:0); //为什么要&&?
                }
            }
        })();
        var strLength = function(_str,_model){
            _model = _model || "Ch"; //En模式下,中文算作1字符;Ch模式下,中文为2个字符
            var _strLen = _str.length; //获取字符串长度
            if(_strLen == 0){
                return 0;
            }else{
                var chinese = _str.match(/[\u4e00-\u9fa5]/g); //匹配中文
                return _strLen + (chinese && _model == "Ch"?chinese.length:0); //为什么要&&?
            }
        }
        var funcRemainingCharacters = function(){
            remainingCharacters = document.getElementById("remainingCharacters");
            var clearRemainingCharacters = function(_this){
                var _value = _this.value;
                var _valueLength = _value.length;
                var dataLength = _this.getAttribute("data-length");
                var dataModel = _this.getAttribute("data-model");
                var subLen = dataLength;
                if(dataModel == "Ch"){//仅当开启Ch后,才对重新计算截取的长度
                    _valueLength = strLength(_value,dataModel);
                    var vv = _value.match(/[\u4e00-\u9fa5]/g); //当输入【哈哈】时,vv是["哈","哈"]数组
                    subLen = dataLength - (!vv?0:vv.length);
                }
                //_valueLength代表总共的字符长度,比如哈哈哈 为 6
                //dataLength是我们定义的限制长度,比如 5
                //subLen是计算的截取长度,当输入家具啊
                if(_valueLength > dataLength){
                    _this.value = _value.substr(0,subLen);
                }
            }
            remainingCharacters.onfocus = function(){
                clearRemainingCharacters(this);
            }
            remainingCharacters.onkeyup = function(){
                clearRemainingCharacters(this);
            }
            remainingCharacters.onblur = function(){
                clearRemainingCharacters(this);
            }
        }
        addLoadEvent(funcRemainingCharacters);
    </script>
复制代码

  全部代码

复制代码
<!doctype html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <link rel="stylesheet" href="http://netdna.bootstrapcdn.com/bootstrap/3.1.1/css/bootstrap.min.css">
    <script type="text/javascript">
        function addLoadEvent(func){
                var oldonload = window.onload;
                if(typeof window.onload != 'function'){
                    window.onload = func;
                }else{
                    window.onload = function(){
                        oldonload();
                        func();
                    }
                }
            }
    </script>
</head>
<body>
    <p class="h3">(支持中英文区分)限制字符串长度</p>
    <div class="container">
    <div class="row">
        <div class="col-md-4">
            <input type="text" class="form-control" data-length="5" id="remainingCharacters" data-model="Ch">
        </div>
    </div>
    </div>
    
    <script type="text/javascript">
        var strLen = (function(){//strlLength的功能相同,但是写法巨麻烦
            return function(_str,_model){
                _model = _model || "Ch"; //En模式下,中文算作1字符;Ch模式下,中文为2个字符
                var _strLen = _str.length; //获取字符串长度
                if(_strLen == 0){
                    return 0;
                }else{
                    var chinese = _str.match(/[\u4e00-\u9fa5]/g); //匹配中文
                    return _strLen + (chinese && _model == "Ch"?chinese.length:0); //为什么要&&?
                }
            }
        })();
        var strLength = function(_str,_model){
            _model = _model || "Ch"; //En模式下,中文算作1字符;Ch模式下,中文为2个字符
            var _strLen = _str.length; //获取字符串长度
            if(_strLen == 0){
                return 0;
            }else{
                var chinese = _str.match(/[\u4e00-\u9fa5]/g); //匹配中文
                return _strLen + (chinese && _model == "Ch"?chinese.length:0); //为什么要&&?
            }
        }
        var funcRemainingCharacters = function(){
            remainingCharacters = document.getElementById("remainingCharacters");
            var clearRemainingCharacters = function(_this){
                var _value = _this.value;
                var _valueLength = _value.length;
                var dataLength = _this.getAttribute("data-length");
                var dataModel = _this.getAttribute("data-model");
                var subLen = dataLength;
                if(dataModel == "Ch"){//仅当开启Ch后,才对重新计算截取的长度
                    _valueLength = strLength(_value,dataModel);
                    var vv = _value.match(/[\u4e00-\u9fa5]/g); //当输入【哈哈】时,vv是["哈","哈"]数组
                    subLen = dataLength - (!vv?0:vv.length);
                }
                //_valueLength代表总共的字符长度,比如哈哈哈 为 6
                //dataLength是我们定义的限制长度,比如 5
                //subLen是计算的截取长度,当输入家具啊
                if(_valueLength > dataLength){
                    _this.value = _value.substr(0,subLen);
                }
            }
            remainingCharacters.onfocus = function(){
                clearRemainingCharacters(this);
            }
            remainingCharacters.onkeyup = function(){
                clearRemainingCharacters(this);
            }
            remainingCharacters.onblur = function(){
                clearRemainingCharacters(this);
            }
        }
        addLoadEvent(funcRemainingCharacters);
    </script>
    <hr>
    <!-- **************************************************************************** -->
</script>
</body>
</html>
复制代码

6 添加CSS函数

复制代码
var setCSS = function(_this,cssOption){
    if(!_this || _this.nodeType === 3 || _this.nodeType === 8 || !_this.style){
        return;
    }
    for(var cs in cssOption){
        _this.style[cs] = cssOption[cs];
    }
    return _this;
};
复制代码

  使用时

setCSS(xxx,{
    "position":"relative",
    "top":"0px"
});

7 自适应文本框

  采用scrollHeight复制给style.height

xxx.style.overflowY = "hidden";
xxx.onkeyup = function(){
    xxx.style.height = xxx.scrollHeight+"px";
};

8 复选框全选、取消和反选

复制代码
//下面html代码
<label class="checkbox-inline">
    <input type="checkbox" name="actionSelects">读书
</label>
<label class="checkbox-inline">
    <input type="checkbox" name="actionSelects">跑步
</label>
<label class="checkbox-inline">
    <input type="checkbox" name="actionSelects">游戏
</label>
<label class="checkbox-inline">
    <input type="checkbox" name="actionSelects">游泳
</label>
//下面是js代码
var targets = document.getElementsByName("actionSelects");
var targetsLen = targets.length;
var i = 0;
document.getElementById("allSelect").onclick = function(){
    for(i=0;i<targetsLen;i++){
        targets[i].checked = true;
    }
}             document.getElementById("cancelAllSelect").onclick = function(){
    for(i=0;i<targetsLen;i++){
        targets[i].checked = false;
    }
}
document.getElementById("_select").onclick = function(){
    for(i=0;i<targetsLen;i++){
        targets[i].checked = !targets[i].checked;
    }
}
复制代码

参考

【1】《超实用的JavaScript代码段》

本文转自博客园xingoo的博客,原文链接:实用的JS代码段(表单篇),如需转载请自行联系原博主。
相关文章
|
10天前
|
前端开发 JavaScript 安全
HTML+CSS+JS密码灯登录表单
通过结合使用HTML、CSS和JavaScript,我们创建了一个带有密码强度指示器的登录表单。这不仅提高了用户体验,还帮助用户创建更安全的密码。希望本文的详细介绍和代码示例能帮助您在实际项目中实现类似功能,提升网站的安全性和用户友好性。
21 3
|
1月前
|
JavaScript 数据安全/隐私保护
2024了,你会使用原生js批量获取表单数据吗
2024了,你会使用原生js批量获取表单数据吗
47 4
|
1月前
|
JavaScript 前端开发 数据安全/隐私保护
前端技术分享:使用Vue.js构建响应式表单
【10月更文挑战第1天】前端技术分享:使用Vue.js构建响应式表单
|
2月前
|
移动开发 JavaScript 前端开发
js之操作表单 | 12-4
js之操作表单 | 12-4
|
2月前
|
移动开发 前端开发 JavaScript
JavaScript 表单
JavaScript 表单
28 9
|
2月前
|
人工智能 前端开发 JavaScript
react js 处理表单( form )的2个例子
react js 处理表单( form )的2个例子
|
3月前
|
大数据 数据处理 分布式计算
JSF 逆袭大数据江湖!看前端框架如何挑战数据处理极限?揭秘这场技术与勇气的较量!
【8月更文挑战第31天】在信息爆炸时代,大数据已成为企业和政府决策的关键。JavaServer Faces(JSF)作为标准的 Java Web 框架,如何与大数据技术结合,高效处理大规模数据集?本文探讨大数据的挑战与机遇,介绍 JSF 与 Hadoop、Apache Spark 等技术的融合,展示其实现高效数据存储和处理的潜力,并提供示例代码,助您构建强大的大数据系统。
49 0
|
3月前
|
Devops 持续交付 测试技术
JSF遇上DevOps:开发流程将迎巨变?一篇文章带你领略高效协同的魅力!
【8月更文挑战第31天】本文探讨了如何在JavaServer Faces(JSF)开发中融入DevOps文化,通过持续集成与部署、自动化测试、监控与日志记录及反馈机制,提升软件交付速度与质量。文中详细介绍了使用Jenkins进行自动化部署、JUnit与Selenium进行自动化测试、ELK Stack进行日志监控的具体方法,并强调了持续改进的重要性。
39 0
|
3月前
|
前端开发 微服务 API
微服务浪潮下的JSF革新:如何在分散式架构中构建统一而强大的Web界面
【8月更文挑战第31天】随着微服务架构的兴起,企业将应用拆分成小型、独立的服务以提高系统可维护性和可扩展性。本文探讨如何在微服务架构下构建和部署JavaServer Faces (JSF) 应用,通过RESTful服务实现前后端分离,提升灵活性和适应性。
59 0
|
3月前
|
JavaScript 前端开发 数据安全/隐私保护
Vue.js 表单处理技巧大揭秘!v-model 与自定义验证综合运用,打造高效表单处理体验!
【8月更文挑战第31天】Vue.js 是一款备受欢迎的前端框架,其表单处理功能强大且灵活。v-model 指令可实现双向数据绑定,简化表单元素值与 Vue 实例数据的同步过程;结合自定义验证规则,则能确保用户输入数据符合特定要求。无论是简单的单字段校验还是复杂的多字段验证,Vue.js 均提供了简洁有效的解决方案,有效提升了表单处理效率及用户体验。通过综合运用 v-model 和自定义验证,开发者能够实时反馈错误信息并控制表单状态,从而增强应用的交互性与可靠性。
58 0