值得一看
双11 12
广告
广告

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

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>

代码解释:

立即学习“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手机号码的提取、过滤和统计功能。这种方法简单有效,能够满足基本的需求。 进一步优化,可以考虑使用更强大的正则表达式进行号码验证,并结合服务器端验证,确保数据的准确性和安全性。

温馨提示: 本文最后更新于2025-08-13 22:40:40,某些文章具有时效性,若有错误或已失效,请在下方留言或联系易赚网
文章版权声明 1 本网站名称: 创客网
2 本站永久网址:https://new.ie310.com
1 本文采用非商业性使用-相同方式共享 4.0 国际许可协议[CC BY-NC-SA]进行授权
2 本站所有内容仅供参考,分享出来是为了可以给大家提供新的思路。
3 互联网转载资源会有一些其他联系方式,请大家不要盲目相信,被骗本站概不负责!
4 本网站只做项目揭秘,无法一对一教学指导,每篇文章内都含项目全套的教程讲解,请仔细阅读。
5 本站分享的所有平台仅供展示,本站不对平台真实性负责,站长建议大家自己根据项目关键词自己选择平台。
6 因为文章发布时间和您阅读文章时间存在时间差,所以有些项目红利期可能已经过了,能不能赚钱需要自己判断。
7 本网站仅做资源分享,不做任何收益保障,创业公司上收费几百上千的项目我免费分享出来的,希望大家可以认真学习。
8 本站所有资料均来自互联网公开分享,并不代表本站立场,如不慎侵犯到您的版权利益,请联系79283999@qq.com删除。

本站资料仅供学习交流使用请勿商业运营,严禁从事违法,侵权等任何非法活动,否则后果自负!
THE END
喜欢就支持一下吧
点赞9赞赏 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容