使用html,css,js 实现一个龙年春节祝福卡片效果

简介: 使用html,css,js 实现一个龙年春节祝福卡片效果


1. Demo 介绍

前天看到掘金酱发的这个活动,便想着参加一下. 毕竟有奖品哈哈哈.

然后呢,我打算实��了一个春节祝福卡片的效果.

这是下面的效果:

  • 点击按钮之后,进入卡片背面,也就是主要内容的一面
  • 可以编辑title 和 content 内容区域
  • content 的文案可以点击小龙随机生成一个

image.png

同时也支持保存当前卡片,保存本地

image.png

2. Demo实现

2.1 布局 和 样式方面

布局:

image.png

2.2 样式和布局 总结

布局和样式倒没有什么可以说的,唯一就是那个卡片3d翻转效果, 主要用到了backface-visibility 属性

2.3 祝福文案随机

祝福文案我让chatGpt 给我生成了一份json格式的数据, 别说,真的蛮方便的. 而且质量也很可以.

image.png

  • 通过fetch 读取到这个json 文件,拿到数据, 进行随机获取, 然后将获取到的数据,插入到页面Dom元素上

js

const btn = document.querySelector('.btn');
        const card = document.querySelector('.card');
        // 获取到龙图元素
        const long = document.getElementById('logo');
        // 获取到祝福文本元素
        const greetings = document.querySelector('.greetings');
        // 获取新年文案的方法
        const getGreet = async () => {
            const res = await fetch('./assets/data.json');
            const data = await res.json();
            //   随机取出data的某一项
            const randomIndex = Math.floor(Math.random() * data.length);
            const randomtext = data[randomIndex].text;
            return randomtext
        }
        
        
        // 插入新年文案
        const insertText = async () => {
            greetings.innerHTML = await getGreet();
        }
        
        // 点击龙切换祝福语
        long.addEventListener('click', function () {
            // 随机文本插入
            insertText()
            // 发出音效
            var audio = new Audio();
            audio.src = './assets/long.mp3';
            audio.autoplay = true;
        })

2.4 祝福人和祝福语,可以直接编辑

contenteditable 是一个 HTML 属性,用于使元素可编辑。当将 contenteditable 属性设置为 "true" 时,元素的内容可以被用户编辑。

html

<div class="title" contenteditable="true">亲爱的掘友们</div>
  <br>
<div class="greetings" contenteditable="true">春节到了, 
    愿您携一份开朗的心情,过好每一天, 做一个积极乐观的人,
    展望一个金灿灿的未来. 身体健康, 万事如意, 心想事成,早日暴富
 </div>

contenteditable 属性在大多数现代浏览器中得到支持,但在某些旧版本的浏览器中可能存在不一致的行为。因此,在使用时要进行兼容性测试,并确保所需的功能在目标浏览器中正常工作。

2.5 截取指定元素的内容,保存图片到本地

这里我们使用到了两个第三方库

  1. html2canvas:它是一个流行的 JavaScript 库,用于在浏览器中将 DOM 元素转换为 canvas。它的主要功能是将网页中的可见内容(包括 HTML 元素、CSS 样式、图像等)绘制到一个 canvas 元素中,从而实现截图、快照或生成图像等功能。
  2. FileSaver.js:它是一个用于在浏览器中保存文件的 JavaScript 库。它提供了一种简单的方法来生成 Blob 对象,并将其保存为本地文件。FileSaver.js 支持在浏览器中保存各种类型的文件,例如文本文件、图像文件、PDF 文件等。

下面展示一下基本的用法:

  • html2canvas

js

const targetElement = document.getElementById('target');
html2canvas(targetElement).then(function(canvas) {
  document.body.appendChild(canvas); // 在页面中插入生成的 canvas 元素
});
  • FileSaver.js

js

const blob = new Blob(['Hello, World!'], { type: 'text/plain;charset=utf-8' });
saveAs(blob, 'hello.txt');

创建一个包含字符串 'Hello, World!'Blob 对象,并使用 saveAs 函数将其保存为名为 'hello.txt' 的文本文件。

介绍完基本用法之后, 看看我们的demo 里面如何写的

  • 获取卡片内容元素,使用html2canvas转换为一个 canvas 对象,然后使用 FileSaver.js 库将 canvas 转换为 Blob 对象并保存为本地文件。

js

function captureAndSave() {
            const targetElement = document.getElementById('target');
            html2canvas(targetElement).then(function (canvas) {
                canvas.toBlob(function (blob) {
                    // 使用 FileSaver.js 保存 Blob 对象到本地文件
                    saveAs(blob, 'screenshot.png');
                });
            });
        }

3. 本Demo使用到的网站

3.1 渐变

grabient

image.png

3.2 按钮

buttons-generator

image.png

3.3 调色板

mycolor

image.png

4. Demo地址

github

gitee

5. 结语

祝大家在新的一年里面, 工作顺利, 身体健康🥰🥰🥰. 向着自己向往的样子而努力奋斗!!!✊✊✊


目录
相关文章
|
12月前
|
存储 前端开发 JavaScript
仿真银行app下载安装, 银行卡虚拟余额制作app,用html+css+js实现逼真娱乐工具
这是一个简单的银行账户模拟器项目,用于学习前端开发基础。用户可进行存款、取款操作,所有数据存储于浏览器内存中
|
人工智能 程序员 UED
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
891 21
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
|
前端开发 JavaScript
【02】v1.0.1更新增加倒计时完成后的放烟花页面-优化播放器-优化结构目录-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
【02】v1.0.1更新增加倒计时完成后的放烟花页面-优化播放器-优化结构目录-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
794 14
【02】v1.0.1更新增加倒计时完成后的放烟花页面-优化播放器-优化结构目录-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
|
前端开发
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
1233 1
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
css3 svg制作404页面动画效果HTML源码
css3 svg制作404页面动画效果HTML源码
309 34
html+js+css实现的建筑方块立体数字时钟源码
html+js+css实现的建筑方块立体数字时钟源码
665 33
|
前端开发
“弘五四,耀青春”程序创意获奖作品【html+css】
本作品以“青春筑梦,共创未来”为主题,采用动态龙元素展现青春活力与创新精神。页面设计简洁明快,色彩协调,突显年轻人积极向上的风貌。作品内容包括获奖截图、名字《时代扬新帆》及源代码分享。特别说明:禁止用于商业活动,可用于比赛和作业等开源场景。最后,作者表达了对五四精神的致敬与传承,强调了青春活力和创造力的重要性,并感谢评委和支持者。 **获奖感言摘录:** “获得这个奖项,对我们团队来说,既是认可也是激励。我们将继续努力,不断优化产品,为用户带来更好的体验,为社会贡献更多价值。”
355 2
|
移动开发 JavaScript 前端开发
[HTML CSS JS ES6 JS WebAPI JQuery]学习笔记目录
[HTML CSS JS ES6 JS WebAPI JQuery]学习笔记目录
|
JavaScript 前端开发 Go
html+js+Jquery(三)
html+js+Jquery(三)
296 1
html+js+Jquery(三)
|
前端开发 测试技术
html+css+js+jQuery学习笔记(一)
html+css+js+jQuery学习笔记
269 0
html+css+js+jQuery学习笔记(一)

热门文章

最新文章

  • 1
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
    519
  • 2
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
    404
  • 3
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
    397
  • 4
    (CSS)使用Flex布局,帮助你快速了解各种基本的Flex布局属性以及帮你让元素快速达到布局中的指定位置!
    259
  • 5
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
    513
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
    685
  • 7
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
    1226
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(三):元素继承关系、层叠样式规则、字体属性、文本属性;针对字体和文本作样式修改
    277
  • 9
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
    1021
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
    477