ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

JS项目练习之求和(包含正则表达式验证)

2019-07-14 18:51:57  阅读:164  来源: 互联网

标签:正则表达式 sum sumInput value JS 求和 cal margin 30px


最近在准备专升本,抽一点时间敷衍一下大家!!!嘿嘿嘿!!!

话不多说,上代码:

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="utf-8">
    <title>求和练习</title>
    <style type="text/css">
        * {
            margin: 0;
            padding: 0;
        }
        .cal-sum {
            width: 500px;
            margin: 100px auto;
        }
        .cal-sum input {
            width: 200px;
            height: 20px;
            padding: 0 5px;
            margin-right: 5px;
        }
        .cal-sum button {
            margin-top: 30px;
            width: 100px;
            height: 20px;
        }
        .cal-sum p {
            margin-top: 30px;
            font-size: 30px;
            color: red;
        }
    </style>
    <script type="text/javascript">
        window.onload = () => {
            const sumInput = document.getElementById('sum_input');
            const sumBtn = document.getElementById('sum_btn');
            const sumValue = document.getElementById('sum_value');

            // 确保输入框只能输入半角‘,’和数字
            // keyup事件,键盘抬起事件
            sumInput.addEventListener('keyup', () => {
                sumInput.value = sumInput.value.replace(/[^(\d)|(,)]/,"");
            });

            sumBtn.addEventListener('click', () => {
                let sum = 0;
                let inputNum = sumInput.value.split(',');
                for (let num in inputNum) {
                    sum += parseInt(inputNum[num]);
                }
                sumValue.innerHTML = sum;
            });
        }
    </script>
</head>
<body>
    <div class="cal-sum">
        <div><input type="text" value="1,2,3,4,5,6" id="sum_input"><span>求数字之和,数字之间用半角‘,’分隔</span></div>
        <button id="sum_btn">求和</button>
        <p><strong id="sum_value"></strong></p>    
    </div>
</body>
</html>

[注]在正则表达式中,^ 在 [] 中代表否定,在这个练习中意思就是:只要不是 ^ 和 数字,当键盘输入抬起后,会自动替换为没有,现象即自动会退回

放假了,也要抽点时间学习呀~~~~

标签:正则表达式,sum,sumInput,value,JS,求和,cal,margin,30px
来源: https://www.cnblogs.com/duxiu-fang/p/11185172.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有