【html】模仿C站动态发红包界面,css+div+js实现布局和交互(适合入门)

news2024/9/24 11:29:10

最近有些小伙伴咨询博主说前端布局好难,其实都是熟能生巧!

模仿C站动态发红包界面,css+div实现布局,纯javascript实现交互效果

目录

1、界面效果

2、界面分析

2.1、整体结构

2.2、标题

2.3、表单

2.4、按钮

3、代码实现

3.1、标题区域布局

3.2、表单区域

3.2.1、祝福语

3.2.2、红包数量

3.2.3、红包总金额

3.2.4、余额支付

3.3、确认按钮区域

4、完整代码

5、基础知识点


1、界面效果

  • 完成效果

  • C站发红包界面 

2、界面分析

2.1、整体结构

上部分为标题、中间为表单、底部为确定按钮

2.2、标题

底部背景、标题文本、右上角关闭按钮

2.3、表单

祝福语文本、红包数量文本、红包总金额、当前余额文本显示、以及前往充值按钮

2.4、按钮

左边为需支付金额显示,右边为取消和确定按钮

3、代码实现

3.1、标题区域布局

1)背景图片

图片宽度380px像素,高度56px像素

2)背景图片自动填充

布局一个div,宽度为400px像素,高度为56px像素,然后再设置背景图片样式,由于图片本身宽度小于div宽度,div会多出20px像素,图片会自动填充,默认效果如下

<div style="width:400px;height:56px;background:url(/1674461966454.jpg);background-size: 100%;">

</div>

 

 3)图片百分比显示

再给div设置背景百分比缩放显示,效果如下

background-size: 100%;

 4)文本

布局一个span标签,显示"添加红包"文本,白色黑体,18号字体,加粗,左对齐,且左边距20px像素。并设置div标签56px像素垂直居中样式,效果如下

5)关闭按钮

在右上角添加一个关闭按钮,一般可以设置一个svg标签图标,设置高28px,宽36px

  • base64编码图标

  • 错位布局

设置相对定位position样式,位于右上角。它所在的父级就要设置绝对定位relative。这样关闭按钮图标就会以它所在的父级定位,否则可能会布局错位,比如下面错位效果

  •  正确布局

  • 样式代码
<style type="text/css">
    .title { width: 400px; height: 56px; background: url(/1674461966454.jpg); background-size: 100%; line-height: 56px;position:relative; }
    .title-text { font-size: 18px; font-weight: bold; color: #fff; font-family: 黑体; margin-left: 20px; }
    .close { position: absolute; top: 0px; right: 0px; width: 36px; height: 28px; }
</style>

<div class="title">
    <span class="title-text">添加红包</span>
    <img class="close" src="" alt="">
</div>

3.2、表单区域

3.2.1、祝福语

1)组成元素

红色星号、文本、输入文本框、刷新文本按钮

2)calc函数

它属于css3的功能,calc() 函数用于动态计算长度值。对于布局非常有作用。

需要特别注意,函数内的参数值前后都需要保留一个空格,例如:width: calc(100% - 40px);

3)刷新小图标

样式设置16x16高宽度



4)文本框默认高亮

input输入文本框默认点击选中会有一个高亮的效果,可以设置样式去掉

outline:none;

5)随机文本

设置随机祝福语文本值,可设置js全局数组参数变量保存。

并且给右边的刷新按钮绑定点击事件,然后在事件内使用随机函数进行随机显示

  • 交互代码
<script type="text/javascript">
    $(function () {

        // 祝福语
        var labelText = ['成就一亿技术人!', '节日快乐', 'Hello World', '新春大吉!', '大吉大利', 'Bug Free'];
        $('.cl-input img').click(function () {
            // Math.random() - 随机函数会产生0~1之间的值
            var index = parseInt(Math.random() * labelText.length);
            var text = labelText[index];
            $('.cl-input input').val(text);
        });
    });
</script>
  • 效果如下

  • 布局代码
<div class="content-label">
    <div class="cl-text">
        <span style="color:#f00;">*</span>
        <span>祝福语</span>
    </div>
    <div class="cl-input">
        <input placeholder="请填写红包祝福语或标题" value="成就一亿技术人!" />
        <img src="" alt="">
    </div>
</div>

3.2.2、红包数量

布局和祝福语一样,刷新按钮换成了单位文本

  • 布局效果

  • 布局代码
<div class="content-label">
    <div class="cl-text">
        <span style="color:#f00;">*</span>
        <span>红包数量</span>
    </div>
    <div class="cl-input">
        <input placeholder="请填写红包数量" value="" />
        <span>个</span>
    </div>
</div>

3.2.3、红包总金额

布局和前面一样,这就是前端布局的魅力,有很多可以重用的东西

  • 布局效果

  • 布局代码 
<div class="content-label">
    <div class="cl-text">
        <span style="color:#f00;">*</span>
        <span>红包总金额</span>
    </div>
    <div class="cl-input">
        <input placeholder="请填写红包总金额" value="" />
        <span>元</span>
    </div>
</div>

3.2.4、余额支付

这里的布局和前面稍微多点东西,布局差不多。

这里只做读取展示用,也可以用input输入文本框,设置默认只读即可

  • 布局效果

  • 布局代码 
<div class="content-label">
    <div class="cl-text">
        <span style="color:#f00;">*</span>
        <span>余额支付</span>
    </div>
    <div class="cl-input">
        <label>当前余额:<b>51.25</b> 元</label>
        <span class="span">前往充值 > </span>
    </div>
</div>

3.3、确认按钮区域

1)支付额文本

这里布局左定位,金额数字加红色字体

2)取消和确认按钮

取消按钮鼠标移动上去边框变深,直接使用css的hover属性即可完成。

确认按钮的效果使用同样的方式

3)布局效果

 

 4)布局代码

<!--按钮-->
<div class="button">
    <div class="price">
        <span>需支付:</span>
        <span id="priceSpan" style="font-size:20px;color:#f00;">0.00</span>
        <span>元</span>
    </div>
    <div class="btn">
        <div class="btnCancel">
            <span>取消</span>
        </div>
        <div class="btnOk not-allowed">
            <span>确定</span>
        </div>
    </div>
</div>

5)交互代码

// 红包个数
var txtCount = 0;
var txtPrice = 0;
$("#txtCount").keyup(function () {
    txtCount = $(this).val();
    $("#priceSpan").html(txtCount * txtPrice);
});

// 红包总金额
$("#txtPrice").keyup(function () {
    txtPrice = $(this).val();
    $("#priceSpan").html(txtPrice);
});

4、完整代码

红包数量和红包金额那里还有几个交互和逻辑判断,有兴趣的小伙伴可以自己实现下,有疑问的可咨询了解

<html>
<head>
    <meta charset="utf-8" />
    <title>红包</title>
    <script src="http://code.jquery.com/jquery-2.1.1.min.js"></script>
    <style type="text/css">
        .area { width: 400px; min-height: 300px; }
        .title { width: 100%; height: 56px; background: url(/1674461966454.jpg); background-size: 100%; line-height: 56px; position: relative; }
        .title-text { font-size: 18px; font-weight: bold; color: #fff; font-family: 黑体; margin-left: 20px; }
        .close { position: absolute; top: 0px; right: 0px; width: 36px; height: 28px; }
        .content { width: calc(100% - 42px); padding: 10px 20px 20px 20px; border: 1px solid #ccc; border-top: none; font-size: 13px; }
        .content-label { margin-bottom: 10px; }
        .cl-text { height: 30px; line-height: 30px; color: #999; }
        .cl-input { width: calc(100% - 2px); border: 1px solid #ccc; border-radius: 5px; height: 40px; line-height: 40px; position: relative; }
            .cl-input input { padding: 10px 50px 10px 10px; width: 100%; outline: none; border: none; background: none; }
            .cl-input img { width: 16px; height: 16px; position: absolute; top: 11px; right: 18px; cursor: pointer; }
            .cl-input span { width: 16px; height: 16px; position: absolute; top: 11px; right: 18px; line-height: 18px; color: #999; }
            .cl-input label { width: 200px; height: 23px; position: absolute; top: 11px; left: 18px; line-height: 18px; color: #333; font-size: 16px; }
                .cl-input label b { font-size: 18px; }
            .cl-input .span { color: #099dff; width: 68px; right: 5px; cursor: pointer; }
        .button { width: 100%; height: 50px; line-height: 50px; position: relative; }
        .price { position: absolute; top: 11px; left: 0px; font-size: 16px; }
        .btn { width: auto; height: 100%; position: absolute; top: 20px; right: 0px; text-align: center; }
        .btnCancel { float: left; width: 70px; border-radius: 30px; height: 30px; line-height: 30px; cursor: pointer;border:1px solid #ddd;margin-right:10px; }
            .btnCancel:hover{border:1px solid #aaa;}
        .btnOk { float: left; width: 70px; border-radius: 30px; height: 30px; line-height: 30px; cursor: pointer; background: #ffa896 !important; color: #fff; }
        .btnOk-ing { background: #ffa896 !important; }
        .not-allowed { cursor: not-allowed; }
    </style>
</head>
<body>
    <div class="area">
        <!--标题-->
        <div class="title">
            <span class="title-text">添加红包</span>
            <img class="close" src="" alt="">
        </div>
        <!--表单-->
        <div class="content">
            <!---->
            <div class="content-label">
                <div class="cl-text">
                    <span style="color:#f00;">*</span>
                    <span>祝福语</span>
                </div>
                <div class="cl-input">
                    <input placeholder="请填写红包祝福语或标题" value="成就一亿技术人!" />
                    <img src="" alt="">
                </div>
            </div>
            <!---->
            <div class="content-label">
                <div class="cl-text">
                    <span style="color:#f00;">*</span>
                    <span>红包数量</span>
                </div>
                <div class="cl-input">
                    <input id="txtCount" placeholder="请填写红包数量" value="" />
                    <span>个</span>
                </div>
            </div>
            <!---->
            <div class="content-label">
                <div class="cl-text">
                    <span style="color:#f00;">*</span>
                    <span>红包总金额</span>
                </div>
                <div class="cl-input">
                    <input id="txtPrice" placeholder="请填写红包总金额" value="" />
                    <span>元</span>
                </div>
            </div>
            <!---->
            <div class="content-label">
                <div class="cl-text">
                    <span style="color:#f00;">*</span>
                    <span>余额支付</span>
                </div>
                <div class="cl-input">
                    <label>当前余额:<b>51.25</b> 元</label>
                    <span class="span">前往充值 > </span>
                </div>
            </div>
            <!--按钮-->
            <div class="button">
                <div class="price">
                    <span>需支付:</span>
                    <span id="priceSpan" style="font-size:20px;color:#f00;">0.00</span>
                    <span>元</span>
                </div>
                <div class="btn">
                    <div class="btnCancel">
                        <span>取消</span>
                    </div>
                    <div class="btnOk not-allowed">
                        <span>确定</span>
                    </div>
                </div>
            </div>
            <!---->
        </div>
    </div>
</body>
</html>

<script type="text/javascript">
    $(function () {

        // 祝福语
        var labelText = ['成就一亿技术人!', '节日快乐', 'Hello World', '新春大吉!', '大吉大利', 'Bug Free'];
        $('.cl-input img').click(function () {
            // Math.random() - 随机函数会产生0~1之间的值
            var index = parseInt(Math.random() * labelText.length);
            var text = labelText[index];
            $('.cl-input input').val(text);
        });

        // 红包个数
        var txtCount = 0;
        var txtPrice = 0;
        $("#txtCount").keyup(function () {
            txtCount = $(this).val();
            $("#priceSpan").html(txtCount * txtPrice);
        });

        // 红包总金额
        $("#txtPrice").keyup(function () {
            txtPrice = $(this).val();
            $("#priceSpan").html(txtPrice);
        });
    });
</script>

5、基础知识点

calc()函数可用于高宽度精准布局,更加合理布局
position和relative相对和绝对定位,同样有助于合理定位和布局
Math.random()       随机函数,随机产生0~1的值

总结:前端布局,要玩出花样和效果,还是需要点艺术天赋。总之,挺有趣的,刚入门可能会觉得比较难,当你熟练之后,还是挺有趣的!

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

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

相关文章

【Kafka】【七】主题和分区的概念

主题和分区的概念 主题Topic 主题-topic在kafka中是⼀个逻辑的概念&#xff0c;kafka通过topic将消息进⾏分类。不同的topic会被订阅该topic的消费者消费。 但是有⼀个问题&#xff0c;如果说这个topic中的消息⾮常⾮常多&#xff0c;多到需要⼏T来存&#xff0c;因为消息是…

Spring Security in Action 第十二章 OAuth 2是如何工作的?

本专栏将从基础开始&#xff0c;循序渐进&#xff0c;以实战为线索&#xff0c;逐步深入SpringSecurity相关知识相关知识&#xff0c;打造完整的SpringSecurity学习步骤&#xff0c;提升工程化编码能力和思维能力&#xff0c;写出高质量代码。希望大家都能够从中有所收获&#…

实战打靶集锦-005-HL

**写在前面&#xff1a;**记录一次曲折的打靶经历。 目录1. 主机发现2. 端口扫描3. 服务枚举4. 服务探查4.1 浏览器访问4.2 目录枚举4.3 探查admin4.4 探查index4.5 探查login5 公共EXP搜索6. 再次目录枚举6.1 探查superadmin.php6.2 查看页面源代码6.3 base64绕过6.4 构建反弹…

JointBERT代码复现详解【下】

BERT for Joint Intent Classification and Slot Filling代码复现【下】 链接直达&#xff1a;JointBERT代码复现详解【上】 四、模型训练与评估 Trainer training&#xff1a;梯度更新evaluate&#xff1a;评估序列标注任务如何得到预测结果、评估函数 1.初始化准备 def …

【Unity3D】Shader常量、变量、结构体、函数

1 源码路径 Unity Shader 常量、变量、结构体、函数一般可以在 Unity Editor 安装目录下面的【Editor\Data\CGIncludes\UnityShader】目录下查看源码&#xff0c;主要源码文件如下&#xff1a; UnityCG.cgincUnityShaderUtilities.cgincUnityShaderVariables.cginc 2 Shader 常…

大数据技术架构(组件)33——Spark:Spark SQL--Join Type

2.2.2、Join Type2.2.2.1、Broadcast Hash Join (Not Shuffled)就是常说的MapJoin,join操作在map端进行的。场景&#xff1a;join的其中一张表要很小&#xff0c;可以放到Driver或者Executor端的内存中。原理:1、将小表的数据广播到所有的Executor端&#xff0c;利用collect算子…

微信小程序 数据绑定 Mustache语法怎么使用?

1.数据绑定的基本原则 ①在data中定义数据 ②在WXML中使用数据、 在页面对应的 .js 文件中。把数据定义到data对象中即可 在WXML文件中使用{{}}两个花括号加变量名称进行调用 以上使用方法&#xff0c;下面我么来实操 Mustache语法主要使用场景如下: 文本内容绑定 组件属性绑定…

Service

目录 文章目录目录本节实战1、Service1.Service概念2.Service存在的意义3.Pod与Service的关系2、三种IP3、定义 Service4、kube-proxy1.iptables2.ipvsiptables vs ipvs5、Service常见类型1.ClusterIP2.NodePort3.LoadBalancer4.ExternalName5.externalIPs6、Endpoints 与 Endp…

Java基础常见面试题(三)

String 字符型常量和字符串常量的区别&#xff1f; 形式上: 字符常量是单引号引起的一个字符&#xff0c;字符串常量是双引号引起的若干个字符&#xff1b; 含义上: 字符常量相当于一个整型值( ASCII 值)&#xff0c;可以参加表达式运算&#xff1b;字符串常量代表一个地址值…

STC15读取内部ID示例程序

STC15读取内部ID示例程序&#x1f389;本案例基于STC15F2K60S2为验证对象。 &#x1f4d1;STC15 ID序列介绍 STC15系列STC最新一代STC15系列单片机出厂时都具有全球唯一身份证号码(ID号)。最新STC15系列单片机的程序存储器的最后7个字节单元的值是全球唯一ID号&#xff0c;用…

使用阿里云IoT Studio建立物模型可视化界面

使用阿里云IoT Studio建立物模型可视化界面 上一篇文章介绍了如何使用ESP-01S上报数据到物模型&#xff1a;https://blog.csdn.net/weixin_46251230/article/details/128996719 这次使用阿里云IoT Studio建立物模型的Web页面 阿里云IoT Studio&#xff1a; https://studio.i…

02 图像通道处理

1 通道提取与合并 在数字图像处理中&#xff0c;图像通道是指一个图像中的颜色信息被分离为不同的颜色分量。常见的图像通道包括RGB通道、灰度通道、HSV通道等。 RGB通道是指将图像分离为红色、绿色和蓝色三个颜色通道&#xff0c;每个通道表示相应颜色的亮度。这种方式是最常…

RuntimeError: CUDA out of memory

今天在训练模型的时候突然报了显存不够的问题&#xff0c;然后分析了一下&#xff0c;找到了解决的办法&#xff0c;这里记录一下&#xff0c;方便以后查阅。 注&#xff1a;以下的解决方案是在模型测试而不是模型训练时出现这个报错的&#xff01; RuntimeError: CUDA out of…

基于JavaEE的智能化跨境电子商务平台的设计

技术&#xff1a;Java、JSP、框架等摘要&#xff1a;伴随着近年来互联网的迅猛发展&#xff0c;网上零售逐渐成为了一种影响广泛、方便快捷的购物渠道。我国网上零售业发展的步伐很快。在如今经济全球化的影响下&#xff0c;消费者的网购行为趋于开放化、多元化&#xff0c;对于…

设计模式-中介者模式详解

定义 中介模式的英文翻译是 Mediator Design Pattern。在 GoF 中的《设计模式》一书中&#xff0c;它是这样定义的&#xff1a; Mediator pattern defines a separate (mediator) object that encapsulates the interaction between a set of objects and the objects delega…

chatGPT都可以干什么呢?来一睹风采吧

文章目录1. 写代码2. 写文案3. 写剧本4. 写歌诗5. 写报告6. 查公式7. 写对联8. 写文章9. 做表格10. 做计划11. 等等1. 写代码 2. 写文案 3. 写剧本 4. 写歌诗 5. 写报告 这妥妥的翻译文&#xff0c;数据完全不对。 6. 查公式 傅里叶变换的时域性质有如下几点&#xff1a; 对…

Android 内存优化(基础轮)必看~

本次分享主要分为五个部分内容&#xff0c;第一部分内容是 5W2H 分析内存优化&#xff0c;第二部分内容是内存管理机制&#xff0c;第三部分内容是内存优化 SOP&#xff0c;第四部分内容是 内存优化指导原则&#xff0c; 最后一部分内容是总结与展望。 如果学完内存优化的基础论…

webgl深入理解视图矩阵

文章目录前言三角形构成三维物体视点、目标、正方向视图矩阵辅助函数&#xff1a;归一化、向量差、点积、叉积视图矩阵的数学表示与使用视图矩阵构建三维世界注意前言 在前面的学习中&#xff0c;已经得知了webgl是如何绘制二维图形&#xff0c;并进行仿射变换&#xff08;矩阵…

mysql的架构图

Mysql逻辑架构图主要分三层&#xff1a;1) 第一层负责连接处理&#xff0c;授权认证&#xff0c;安全等等每个客户端连接都会在服务器进程中拥有一个线程&#xff0c;服务器维护了一个线程池&#xff0c;因此不需要为每一个新建的连接创建或者销毁线程。当客户端连接到Mysql服务…

基于JavaEE的“三味”书屋网上售书系统

技术&#xff1a;Java、JSP等摘要&#xff1a;美国最先提出Internet的概念,如今,全球各地的人们纷纷加入到这个网络行列, 使 Internet 真正走向全球化。随着用户、网民越来越多,网络的范围也愈来愈大,领域也慢慢走向了多元化&#xff0c;一体化 。“三味”书屋设计就是网络浪潮…