百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

从案例中学习JavaScript,超简单函数封装技巧

suiw9 2024-10-23 18:47 35 浏览 0 评论

说实话我有点吃惊,用js写的对话效果在当天都就被多个专题收录,而且直接被推荐到首页。我怎么也没有想到随便写的一个小例子会这么受关注,莫非是因为贴图的关系?

嘛,无所谓这些小细节了。

既然如此,我们就把这个对话效果做得完善一些吧。上一节《从案例中学习JavaScript》之实现对话效果 中,我们主要通过 setInterval 方法做了一个轮询,从而实现了字符串的动画打印效果。但是,还不够完善,比如,一旦字符长度超过了div的边界,文字就会溢出。当然,你可以给div加上一个 overflow:hidden 的样式,可是这样的话,就无法完整地显示出对话了。

我们开始逐步解决这个问题,最终实现的效果就是,文字填满对话框的时候,自动停住,需要用户手动去点击一下,然后进行下一段对话。

本章主要讲函数的封装。

本节涉及的知识点:

  • 函数的封装技巧

下节涉及的知识点:

  • div元素的 scrollHeight 和 clientHeight
  • 开关变量的使用技巧

有朋友反应说案例文章太长,因此我决定多分几章来写,争取每一篇都能把东西彻底讲清楚,而又不至于看起来太累。

追求精炼和简洁。

我希望通过本文,让那些刚踏入 js 巨坑的朋友们彻底明白如何快速,有效地封装一个方法。当然,等你熟练了以后就无所谓了,爱怎么写怎么写。

好了,开始吧。

1. 页面重构

本期我对之前的页面进行了一次重构,我在原先的innerBox里面又嵌套了一个div,目的是为了让文字区域的定位显得更加灵活。不像之前那样紧挨着边框,不是太美观。

现在的效果:

对了,目录结构也做了一些调整:

Paste_Image.png

代码如下:

css

body {

background: url(../img/bg.jpg) no-repeat;

background-size: 100%;

}

.dialog {

width:100%;

height:100px;

background:rgba(136,180,251,0.5);

position:absolute;

bottom: 0;

}

.dialog .pic {

width:60px;

height:60px;

background:url(../img/1.png) no-repeat;

background-size: 100%;

display:inline-block;

position: absolute;

top:16px;

left:16px;

border-radius: 5px;

}

.dialog .innerBox{

width:90%;

height:80px;

border:2px solid #dcc0a5;

opacity: 0.8;

left:85px;

top:10px;

position: absolute;

border-radius: 5px;

font-family: 微软雅黑;

color:#fff;

text-shadow: 1px -1px 1px #333;

padding:2px;

}

.dialog .innerBox #content {

background: #E10482;

margin:2px 10px 10px 10px;

width:95%;

height:99%;

ine-height:25px;

overflow: hidden;

font-size: 20px;

}

html:

<body>
 <div class='dialog'>
 <span class='pic'></span>
 <div id = 'innerBox' class='innerBox'>
 <div id='content'></div>
 </div>
 </div>
</body>

这样就可以灵活地控制文字区域了,我们的文字就在content区域显示出来,定位好后,别忘了将背景色给去掉。

.dialog .innerBox #content {
 /*background: #E10482;*/
 margin:2px 10px 10px 10px;
 width:95%;
 height:99%;
 ine-height:25px;
 overflow: hidden;
 font-size: 20px;
}

去掉背景色之后:

对于初学者,我建议画图层的时候先加个背景色,这样会清晰很多,确定没问题之后,再把背景色给去掉。当然,css高端玩家就忽略我说的话吧。

2. 方法的封装

让我们找到上一节的代码,开始进行方法封装。

var innerBox = document.getElementsByClassName('innerBox')[0];
var text = 'JavaScript一种直译式脚本语言,是一种动态类型、弱类型、基于原型的语言,内置支持类型。它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在HTML(标准通用标记语言下的一个应用)网页上使用,用来给HTML网页增加动态功能。天空,你也要好好学习呀!';
var len = text.length;
var timer = null;
var index = 0;
timer = setInterval(function(){
 if(index == len){
 clearInterval(timer);
 }
 innerBox.innerHTML += text.charAt(index++);
},50);

封装方法我认为可以分为以下几个步骤:

  • 零散地写代码,先把功能实现了再说。
  • 找不同,就是看哪些地方是不一定的。
  • 复制
  • 粘贴

这是我自己总结出来的,理论我们不多说,我直接上代码,把我的做法和思路写出来,你一看就懂了。

2.1 零散地写代码,先把功能实现了再说。

这一步,我们在上一个章节已经实现。

2.2 找不同,就是看那些地方是不一定的。

这个太简单了,就是你看一看自己写的代码中,哪些东西有可能是动态的。

让我们仔细观察上面的代码,最起码有以下三个地方是不确定的。

首先,获取的dom元素不确定。我们完全可以传入一个id,然后再函数里面用document.getElementById 来包裹一下。其次,需要显示的文本内容不确定。最后,对话的速度也不确定,也就是轮询的时间间隔,数值越小,速度越快。

这些不确定的地方 就是 函数需要传入的参数。

所以,一个函数的模型就出来了。

/**
 * 游戏对话
 * @param {string} id 对话框的id
 * @param {string} text 对话文本
 * @param {number} speed 速度
 */
var gameDialog = function(id,text,speed){
}

2.3 复制

现在,我们原封不动地将之前的代码拷贝到函数里。为了看起来更直观,我们采用 document.getElementById 的方式来获取dom元素。源代码在这里改动一下。

var gameDialog = function(id,text,speed){
 var innerBox = document.getElementById('content');
 var text = '文本内容';
 var len = text.length;
 var timer = null;
 var index = 0;
 
 timer = setInterval(function(){
 if(index == len){
 clearInterval(timer);
 }
 innerBox.innerHTML += text.charAt(index++);
 },50);
}

是的,原封不懂地复制。

2.4 粘贴

最后一步就是填空题,小学题目了,把参数对好了一个个填进去。

Paste_Image.png

ctrl + c , ctrl + v

ctrl + c , ctrl + v

ctrl + c , ctrl + v

var gameDialog = function(id,text,speed){
 var innerBox = document.getElementById(id);
 var text = text;
 var len = text.length;
 var timer = null;
 var index = 0;
 
 timer = setInterval(function(){
 if(index == len){
 clearInterval(timer);
 }
 innerBox.innerHTML += text.charAt(index++);
 },speed);
}

OK,完成!

就这么轻松加随意。

当然,可能有人会问,如果不确定的地方很多咋办,我总不可能写上十几个参数吧。先卖个关子,以后会详细说到。

测试

gameDialog('content',
 " 简书客户端中包含杂文时政、小说诗歌、电影评论、科技新闻,无论你的兴趣如何构成,总能在这里找到志趣相投的作者与内容。"+
 " 简书始终致力于做中文世界最好的写作与阅读平台,集结最优秀的创作者与文字爱好者,在嘈杂喧嚣的网络时代,重新沉淀并唤醒文字的力量。"
,38);

Paste_Image.png

封装的好处不言而喻,我们只需要传入参数,打个括号就可以直接调用方法了,不再需要每次都把实现代码写一遍,这样极大程度上实现了代码的复用。

相关推荐

5款Syslog集中系统日志常用工具对比推荐

一、为何要集中管理Syslog?Syslog由Linux/Unix系统及其他网络设备生成,广泛分布于整个网络。因其包含关键信息,可用于识别网络中的恶意活动,所以必须对其进行持续监控。将Sys...

跨平台、多数据库支持的开源数据库管理工具——DBeaver

简介今天给大家推荐一个开源的数据库管理工具——DBeaver。它支持多种数据库系统,包括Mysql、Oracle、PostgreSQL、SLQLite、SQLServer等。DBeaver的界面友好...

强烈推荐!数据库管理工具:Navicat Premium 16.3.2 (64位)

NavicatPremium,一款集数据迁移、数据库管理、SQL/查询编辑、智能设计、高效协作于一体的全能数据库开发工具。无论你是MySQL、MariaDB、MongoDB、SQLServer、O...

3 年 Java 程序员还玩不转 MongoDB,网友:失望

一、什么场景使用MongoDB?...

拯救MongoDB管理员的GUI工具大赏:从菜鸟到极客的生存指南

作为一名在NoSQL丛林中披荆斩棘的数据猎人,没有比GUI工具更称手的瑞士军刀了。本文将带你围观五款主流MongoDB管理神器的特性与暗坑,附赠精准到扎心的吐槽指南一、MongoDBCompass:...

mongodb/redis/neo4j 如何自己打造一个 web 数据库可视化客户端?

前言最近在做neo4j相关的同步处理,因为产线的可视化工具短暂不可用,发现写起来各种脚本非常麻烦。...

solidworks使用心得,纯干货!建议大家收藏

SolidWorks常见问题...

统一规约-关乎数字化的真正实现(规范统一性)

尽管数字化转型的浪潮如此深入人心,但是,对于OPCUA和TSN的了解却又甚少,这难免让人质疑其可实现性,因为,如果缺乏统一的语义互操作规范,以及更为具有广泛适用的网络与通信,则数字化实际上几乎难以具...

Elasticsearch节点角色配置详解(Node)

本篇文章将介绍如下内容:节点角色简介...

产前母婴用品分享 篇一:我的母婴购物清单及单品推荐

作者:DaisyH8746在张大妈上已经混迹很久了,有事没事看看“什么值得买”已渐渐成了一种生活习惯,然而却从来没有想过自己要写篇文章发布上来,直到由于我产前功课做得“太过认真”(认真到都有点过了,...

比任何人都光彩照人的假期!水润、紧致的肌肤护理程序

图片来源:谜尚愉快的假期临近了。身心振奋的休假季节。但是不能因为这种心情而失去珍贵的东西,那就是皮肤健康。炙热的阳光和强烈的紫外线是使我们皮肤老化的主犯。因此,如果怀着快乐的心情对皮肤置之不理,就会使...

Arm发布Armv9边缘AI计算平台,支持运行超10亿参数端侧AI模型

中关村在线2月27日消息,Arm正式发布Armv9边缘人工智能(AI)计算平台。据悉,该平台以全新的ArmCortex-A320CPU和领先的边缘AI加速器ArmEthos-U85NPU为核心...

柔性——面向大规模定制生产的数字化实现的基本特征

大规模定制生产模式的核心是柔性,尤其是体现在其对定制的要求方面。既然是定制,并且是大规模的定制,对于制造系统的柔性以及借助于数字化手段实现的柔性,就提出了更高的要求。面向大规模定制生产的数字化业务管控...

创建PLC内部标准——企业前进的道路

作者:FrankBurger...

标准化编程之 ----------- 西门子LPMLV30测试总结

PackML乃是由OMAC开发且被ISA所采用的自动化标准TR88.00.02,能够更为便捷地传输与检索一致的机器数据。PackML的主要宗旨在于于整个工厂车间倡导通用的“外观和感觉”,...

取消回复欢迎 发表评论: