PHP表单textarea中提取和统计有效手机号码

DDD
发布: 2025-08-13 22:24:15
原创
509人浏览过

php表单textarea中提取和统计有效手机号码

本文介绍如何使用JavaScript在PHP表单的textarea字段中提取并统计有效的10位手机号码。通过监听mouseout事件,在用户离开textarea后,脚本会自动过滤掉无效号码,仅保留符合要求的10位数字号码,并更新号码计数。这种方法既保证了数据清洗,又保留了号码统计功能。

实现步骤

  1. HTML表单结构:

首先,确保你的HTML表单包含一个textarea字段用于输入手机号码,以及一个只读的input字段用于显示号码计数。

<form class="form" method="post" enctype="multipart/form-data">
    <div class="form-group row">
        <label for="title" class="col-lg-2 col-form-label">Mobile Numbers </label>                         
        <div class="col-lg-10">
            <textarea require  type="text" class="form-control required" required 
        cols="10" rows="7" id="mobileno" name="mobileno"> </textarea>
        </div>
    </div>

    <div class="form-group row">
        <label class="col-lg-2 control-label " for="userName">Number Count </label>
        <div class="col-lg-10">
            <input type="text" class="form-control " readonly id="numbercount" required name="numbercount" value="">
        </div>
    </div>

    <div class="form-group row">
        <div class="col-lg-12 text-center">
            <button id="btn" type="submit" name="submit" class="btn btn-success btn-lg waves-effect waves-light m-r-10">SUBMIT </button>
        </div>
    </div>
</form>
登录后复制
  1. JavaScript代码:

接下来,使用JavaScript来处理textarea中的数据。主要步骤包括:

  • 获取textarea和计数input的引用。
  • 监听textarea的mouseout事件。
  • 在事件处理函数中,获取textarea的值,按行分割。
  • 遍历每一行,检查是否为有效的10位数字号码。
  • 将有效的号码重新拼接成字符串,更新textarea的值。
  • 更新号码计数input的值。
<script>
let numbers =document.querySelector('#mobileno');
let numbercount =document.querySelector('#numbercount');
addEventListener('mouseout',getNumbers);
function getNumbers(event){
event.preventDefault();
let getnums = numbers.value.trim();
getnums = getnums.split("\n");

let result = "";
let totalNum = 0;
getnums.forEach(num => {
    if(num.length ==10 && num.indexOf("+")){
        result += num.substring(0, 10) + "\n";
        totalNum++;
    }
});
numbers.value = result;
numbercount.value = totalNum;
}
</script>
登录后复制

代码解释:

表单大师AI
表单大师AI

一款基于自然语言处理技术的智能在线表单创建工具,可以帮助用户快速、高效地生成各类专业表单。

表单大师AI 74
查看详情 表单大师AI

立即学习PHP免费学习笔记(深入)”;

  • document.querySelector('#mobileno') 和 document.querySelector('#numbercount'):分别获取textarea和计数input的DOM元素。
  • addEventListener('mouseout',getNumbers):为textarea添加mouseout事件监听器,当鼠标移出textarea时触发getNumbers函数。
  • event.preventDefault():阻止默认事件行为。
  • numbers.value.trim():获取textarea的值,并去除首尾空格。
  • getnums = getnums.split("\n"):将textarea的值按行分割成数组。
  • getnums.forEach(num => { ... }):遍历号码数组,对每个号码进行验证。
  • if(num.length ==10 && num.indexOf("+")):检查号码长度是否为10位,且不包含"+"号,以确保为有效的手机号码。
  • result += num.substring(0, 10) + "\n":将有效的号码添加到结果字符串中,并添加换行符。
  • totalNum++:增加有效号码计数。
  • numbers.value = result:更新textarea的值为过滤后的有效号码。
  • numbercount.value = totalNum:更新号码计数input的值。

注意事项

  • 错误处理: 在实际应用中,可以添加更完善的错误处理机制,例如,使用正则表达式更精确地验证手机号码格式。
  • 用户体验: 可以考虑使用input事件或keyup事件,实时更新号码计数,提供更好的用户体验。但需要注意性能优化,避免频繁更新DOM导致页面卡顿。
  • 服务器端验证: 务必在服务器端对提交的手机号码进行再次验证,防止恶意用户绕过客户端验证。

总结

通过以上步骤,你就可以在PHP表单中实现textarea手机号码的提取、过滤和统计功能。这种方法简单有效,能够满足基本的需求。 进一步优化,可以考虑使用更强大的正则表达式进行号码验证,并结合服务器端验证,确保数据的准确性和安全性。

以上就是PHP表单textarea中提取和统计有效手机号码的详细内容,更多请关注php中文网其它相关文章!

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号