JavaScript统计字符出现次数

 更新时间:2021年03月05日 07:22:05   作者:左一.  
这篇文章主要为大家详细介绍了JavaScript字符统计出现次数,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了JavaScript统计字符出现次数的具体代码,供大家参考,具体内容如下

统计用户输入字符串中各字符出现的次数。

例如:输入字符串为”abca12abbc121d”,输出为:a出现3次,b出现3次,c出现2次,d出现1次,1出现3次,2出现2次。

方法一

<script>
 var ary ="abca12abbc121d";
 
 var obj = {};
 var i = 0;
 ary1 = ary.toLocaleLowerCase(); 
 
 for(i = 0; i < ary1.length; i++)
 {
 key = ary1[i];
 if(obj[key])
 {
 //对象中有这个字母
 obj[key]++;
 }
 else
 {
 //对象中没有这个字母,把字母加到对象中
 obj[key] = 1;
 }
 }
 
 for(var key in obj) //遍历这个对象
 {
 console.log(key + "这个字符出现了" + obj[key] + "次");
 }
</script>

效果如下:

这个方法是利用了开发者工具来实现的

方法二

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <title>Document</title>
 <script src="sc/char-sunmmary.js"></script>
 <script>
 window.onload=function(){
  var txtChars=document.getElementById("txt-chars");
  var show=document.getElementById("show");
  document.getElementById("btn-ok").onclick=function(){
  var str=txtChars.value;
  var charTotal=total(str);
  // 降序
  charTotal.sort(function(a,b){
   return (a.count-b.count)*-1;
  })
  
  show.innerHTML="<ul>";
  //slice(0,5)取前五
  for(var ct of charTotal.slice(0,5)){
   show.innerHTML+="<li>"+ct.char+"出现了"+ct.count+"次</li>";
  }
  show.innerHTML+="</ul>";
  }
 }
 </script>
</head>
<body>
 <label for="txt-chars">请输入一串字符:</label>
 <input type="text" id="txt-chars" name=""/>
 <button id="btn-ok">确定</button>
 <p id="show"></p>
</body>
</html>

char-sunmmary.js

function Summary(char,count) {
 this.char=char;
 this.count=count;
}
// 传递字符串,返回出现频率
function total(str) {
 var result=[];
 for(var c of str){
 var charObj=checkChar(result,c);
 if(charObj==null){
  result.push(new Summary(c,1));
 }
 else{
  charObj.count++;
 }
 }
 return result;
}
// 在数组arr中查找包含字符char的summary实列
//如果存在,则返回该实例,否则返回null
function checkChar(arr,char) {
 var r=null;
 for(var c of arr){
 if(c.char==char){
  r=c;
  break;
 }
 }
 return r;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 一文带你快速学会JavaScript条件判断及高级用法

    一文带你快速学会JavaScript条件判断及高级用法

    JavaScript支持其用于执行根据不同的条件不同的操作条件语句,下面这篇文章主要给大家介绍了关于如何在JavaScript中更好的使用条件判断的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-09-09
  • js与jquery获取父元素,删除子元素的两种不同方法

    js与jquery获取父元素,删除子元素的两种不同方法

    本篇文章主要是对js与jquery获取父元素,删除子元素的两种不同方法进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2014-01-01
  • JavaScript的垃圾回收机制与内存管理

    JavaScript的垃圾回收机制与内存管理

    这篇文章主要介绍了JavaScript的垃圾回收机制与内存管理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • layui树形菜单动态遍历的例子

    layui树形菜单动态遍历的例子

    今天小编就为大家分享一篇layui树形菜单动态遍历的例子,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-09-09
  • JavaScript实现简易tab栏切换内容栏

    JavaScript实现简易tab栏切换内容栏

    这篇文章主要为大家详细介绍了JavaScript实现简易tab栏切换内容栏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-05-05
  • 基于JavaScript代码实现自动生成表格

    基于JavaScript代码实现自动生成表格

    本文给大家分享一段js代码实现输入表格行数、列数自动生成表格源代码,非常不错具有参考借鉴价值,感兴趣的朋友一起学习吧
    2016-06-06
  • JS中实现replaceAll的方法(实例代码)

    JS中实现replaceAll的方法(实例代码)

    本文是对JS中实现replaceAll的方法进行了详细的总结介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2013-11-11
  • javascript 函数声明与函数表达式的区别介绍

    javascript 函数声明与函数表达式的区别介绍

    javascript中的函数声明与函数表达式使用比较频繁,可能很多的朋友都不知道他们之间的区别,在此为大家详细介绍下,希望对大家有所帮助
    2013-10-10
  • 微信小程序实现顶部固定 底部分页滚动效果

    微信小程序实现顶部固定 底部分页滚动效果

    这篇文章主要介绍了微信小程序实现顶部固定底部分页滚动效果,本文大概给大家分享三种解决方案,每种方案给大家详细剖析通过代码解析哪种方案更适合,感兴趣的朋友跟随小编一起看看吧
    2022-10-10
  • JS使用eval()动态创建变量的方法

    JS使用eval()动态创建变量的方法

    这篇文章主要介绍了JS使用eval()动态创建变量的方法,详细分析了eval函数的功能及使用eval函数实现动态创建变量的步骤与相关注意事项,需要的朋友可以参考下
    2016-06-06

最新评论