利用JavaScript實現仿QQ個人資料卡效果
前言
最近在學習前端的知識,無意間發現QQ 那個個人資料卡還挺好看的,就想著自己能不能照著原版搞出一個高仿出來,話不多時直接開始先睡上一覺,找找靈感,睡醒來又餓瞭,出去吃個飯,回來天tm都黑瞭,哈哈哈哈,金今天又是擺爛的一天,啊啊啊,不行至少今天這篇博客得寫個前言部分…於是乎我們來到第二天,開始幹(要幹啥來著,幸虧昨天還寫瞭個標題,要不然都忘瞭——HTML+CSS+JS實現仿QQ個人資料卡)
不多逼逼直接上幹貨
思路
首先我們先這樣,然後那樣,再然後這樣,最後再那樣,好,完成瞭,請看效果圖:
正經點,我們重新開始
首先我們先參考一下QQ原生資料卡
這個資料卡乍一看好像其實並沒有覺得很復雜,但是如果往細瞭看(多細?比吳簽還細嗎?)
…
隻能弱弱的說一句:臥槽,真復雜啊,我們把圈起來的搞出來就行瞭吧,偷個小懶,哈哈哈
先聊聊思路:任何前端頁面都是由一個個小模塊拼接組成的,我們先將它們的每一個模塊劃分出來,在添加上對應得描述,超鏈接和文字即可
模塊化:將整個主頁模塊化
我們就像拼拼圖一樣,先做好每一個小區域,然後將他們品“拼起來就行瞭“
如下圖:
首先看圈出來的東西,我們可以把這個頁面分為圖標,按鈕和文字三個部分,包含各類樣式; 圖標:讓我們的鼠標點到它,給出一個“反應”
按鈕則是包含相關內容的一個盒子,加上對應內容的超鏈接即可,並且有選中和未選中的兩種不同狀態:
- 被選中時,先稍微多放大一些,然後字體顏色由黑色改變為藍色;
- 未選中時,則保持原狀態不變;
文字:直接代碼中添加,然後確定位置即可
話不多說,上代碼:
實現代碼
HTML
<!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>歡迎來到小新的個人主頁</title> <link rel="stylesheet" href="css/style.css" rel="external nofollow" > <link rel="icon" href="index_1.html" rel="external nofollow" > <audio src="etc/qfl.mp3" id="audio"></audio> </head> <body> <div class="container"> <div class="user-form"> <div class="bg-user"> <div class="top"><img src="images/riluo.jpg"></div> <div class="circle"><img src="http://q1.qlogo.cn/g?b=qq&nk=2085324623&s=640"></div> <p class="user-title">   五月</p> <p class="user-qq">QQ: 2085324623</p> <div class="idcard"><img src="images/svip.png"></div> <div class="zan"><img src="images/zan.png"></div> <p class="sign-text"><img src="images/person.jpeg"> 男 | 金牛座 | 中國 </p> <p class="sign-text"><img src="images/sign.jpeg"><a href="https://blog.csdn.net/m0_68089732" rel="external nofollow" >#將溫柔寄予信~</a></p> <p class="sign-text"><img src="images/qzone.jpeg"><a href="https://mp.qzone.qq.com/u/327893?uin=2085324623&is_famous_space=0&brand_flag=0" rel="external nofollow" > Ta的空間</a></p> <p class="sign-text"><img src="images/camera.jpeg"> 精選照片</p> <div class="border-img"><img src="images/012.gif"></div> <button class="btn-blue" onclick="window.open('tencent://message/?uin=2085324623&Menu=yes')">添加好友</button> <button class="btn-music" id="music">音樂設置</button> </div> </div> </div> <script src="js/jquery-1.11.0.min.js"></script> <script src="js/sweetalert.min.js"> </script> <script src="js/main.js"></script> </body> </html>
CSS
*{ padding: 0px; margin:0px; font-family: "Arial","Microsoft YaHei","黑體","宋體",sans-serif; } body::before{ content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: linear-gradient(125deg,#c5e6e8,#ced396,#a1c4fd,#a8edea,#d299c2); /*background: transparent url('../img/bg.jpg') no-repeat fixed;*/ /*filter: blur(8px);*/ background-size: cover; z-index: -1; } .container{ position: absolute; transform: translate(-50%,-50%); left: 50%; top:50%; } .btn-blue{ display: block; width:100%; height: 40px; margin-top:10px; background-color: #a1c4fd; border:2px solid #a1c4fd; border-color: #a1c4fd; border-radius: 5px 5px 5px 5px; outline: none; color:#fff; transition: 0.3s; transform: translateZ(0); } .btn-blue:hover{ transform: scale(1.01); box-shadow: 0 4px 8px 0 rgba(0,0,0,0.2); } /**************************/ .bg-user{ width: 300px; padding: 20px; background-color: #fff; border-radius: 15px; transition: 0.3s; } .circle > img{ border:0px solid #fff; height:80px; width: 80px; border-radius: 50%; margin-top: -50px; } @keyframes rotation{ from { transform: rotate(0deg); } to { transform: rotate(360deg); } } .circle > img:hover{ animation: rotation 3s linear infinite; } .user-title{ position: relative; display: inline; float: right; margin-top: -65px; margin-right: 160px; color:#ffffff; font-size: 15px; font-weight: 500; } .user-qq{ display: inline; float: right; margin-top: -30px; margin-right: 100px; font-size:15px; font-weight: 300; } .top{ margin-top: -10px; margin-left: -10px; margin-right: -10px; } .top > img{ width: 100%; height: 200px; border:0px solid #fff; border-radius: 15px; } .idcard{ float: right; margin-top: -30px; margin-right: 45px; } .idcard > img{ width: 40px; height: 13px; } .zan{ position: relative; display: inline; float: right; margin-top: -75px; margin-right: -30px; transition: 0.5s; } .zan:hover{ transform: scale(1.05); transform:rotate(10deg); -ms-transform:rotate(10deg); /* IE 9 */ -moz-transform:rotate(10deg); /* Firefox */ -webkit-transform:rotate(10deg); /* Safari 和 Chrome */ -o-transform:rotate(10deg); } .zan > img{ height: 40%; width: 50%; } .sign-text{ text-align: left; font-size: .85rem; margin-top: 10px; cursor: default; } .sign-text:hover{ transition: 0.3s; color: #007bff; transform: scale(1.05); } a{ text-decoration:none; color: inherit; } .sign-text>img{ width:20px; height:20px; vertical-align:middle; } .sign-img{ text-align: left; font-size: .85rem; margin-top: 10px; cursor: default; } .sign-img:hover{ transition: 0.3s; color: #007bff; transform: scale(1.05); } .border-img > img{ width: 100%; margin-top: 10px; border: 2px solid rgba(0,0,0,0.2); border-radius: 15px; transition: 0.3s; } .whj{ float:right; } .border-img > img:hover{ box-shadow: 0 4px 8px 0 rgba(0,0,0,0.2); } .btn-music{ display: block; width:100%; height: 40px; margin-top:10px; background-color: #fecfef; border:2px solid #fecfef; border-color: #fecfef; border-radius: 5px 5px 5px 5px; outline: none; color:#fff; transition: 0.3s; } .btn-music:hover{ transform: scale(1.01); box-shadow: 0 4px 8px 0 rgba(0,0,0,0.2); }
背景音樂
這裡突發奇想想添加個,能穿越時空的音樂——帶你回到18年的夏天,還附贈瞭一個視頻,轉載自b站,所以外加瞭個JS,最後連接到HTML即可。
JavaScript
function playMusic() { var audioEle = document.getElementById("audio"); if (audioEle.paused){ audioEle.play(); }else { audioEle.pause(); } } $("#music").click(function(){ play(); }); var player = document.getElementById("audio"); play(); function play(){ swal("點擊開啟音樂-起風瞭\n可以邊瀏覽邊聽哦~", { buttons: { cancel: "開啟", allow: "關閉" } }).then(function(value) { if (value == "allow") { player.pause() } else { player.play(); } }); }
最終效果
知識點補充
window.open('tencent://message/?uin=2085324623&Menu=yes')"
添加自己的QQ號,點擊對應按鈕,即可打開QQ,跳轉添加好友頁面
"https://mp.qzone.qq.com/u/327893?uin=2085324623&is_famous_space=0&brand_flag=0"
喚醒QQ ,跳轉個人QQ空間
到此這篇關於利用JavaScript實現仿QQ個人資料卡效果的文章就介紹到這瞭,更多相關JavaScript仿QQ個人資料卡內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!