cnblogs 博客布局
cnblogs 博客布局代码
cnblogs 博客布局代码
cnblogs 博客布局代码
cnblogs 博客布局代码
01) 页面订制 css 代码
 
/* ********************** * 整体布局 * **********************/ /* 整体布局 */ body { background: #e6ecf0; font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica Neue, PingFang SC, Hiragino Sans GB, Microsoft YaHei, sans-serif; } #home { max-width: 1140px; padding: 15px; background: transparent; box-shadow: none; margin-top: 0; width: auto; } #main { margin-top: 15px; } #mainContent .forFlow { padding-right: 20px; } /* 非阅读区域去掉白色背景 */ .newsItem, .catListEssay, .catListLink, .catListNoteBook, .catListTag, .catListPostCategory, .catListPostArchive, .catListImageCategory, .catListArticleArchive, .catListView, .catListFeedback, .mySearch, .catListComment, .catListBlogRank, .catList, .catListArticleCategory { background-color: transparent; } /* ********************** * 博客页首 * **********************/ /* 隐藏系统标题 */ #blogTitle { display: none; } /* 顶部通告条 */ .c-notice { padding: 10px 0; background: tan; font-size: 0.9em; box-shadow: 0 2px 6px rgba(0, 0, 0, 0.16), 0 2px 6px rgba(0, 0, 0, 0.23); font-size: 15px; } .c-notice > div { max-width: 1140px; margin: 0 auto; padding: 0 15px; } .c-notice a { color: blue; } /* 头像和社交 */ .c-portrait { text-align: center; padding: 50px 0; background: #39424b; color: #fff; /* margin-bottom: -40px; */ } /* 头像 */ .c-portrait > img { display: inline-block; height: 80px; border-radius: 50%; } /* 标题和签名 */ .c-portrait h1 { font-size: 25px; font-weight: bold; margin: 5px 0; } .c-portrait h1 a { color: #fff; } .c-portrait h2 { font-size: 16px; margin: 7px 0 10px; color: #ccc; } /* 社交图标 */ .c-social a { color: #959da5; display: inline-block; vertical-align: middle; } /* ********************** * 导航栏 * **********************/ #navigator { padding: 0 10px; border-bottom: 2px solid #ccc; } #stats_article_count { display: none; } /* ********************** * 侧边栏 * **********************/ #sideBar { width: 250px; margin-top: 0; } #sideBar a { color: inherit; } /* 隐藏侧边公告标题 */ .newsItem .catListTitle { display: none; } /* 增加列表项间距 */ .sidebar-block li { margin-bottom: 5px; } /* ********************** * 文章列表 * **********************/ /* 文章列表 */ #topics .postTitle { font-size: 28px; margin: 35px 0 30px; padding-left: 0; } #mainContent .day { padding: 15px 20px; background: #fff; } #mainContent .day .postTitle a { display: inline-block; } /* ********************** * 文章详情 * **********************/ pre { margin-bottom: 1.35em; } pre code { padding: 10px 16px !important; } .post { background: #fff; padding: 0 60px 60px; box-shadow: 0 2px 6px rgba(100, 100, 100, 0.3); } /* 文章标题 */ .postTitle { border-left: 8px solid #21759b; margin-bottom: 5px; font-weight: bold; line-height: 1; box-sizing: border-box; } .postTitle a:hover { margin-left: 0; } /* 去除首行缩进 */ .postBody p, .postCon p { text-indent: 0; } /* 重写引用块样式 */ .postBody blockquote { min-height: auto; border-top: none; border-bottom: none; border-right: none; padding: 0 0 0 1em; } /* 增加底部留白 */ #cnblogs_post_body { padding-bottom: 5px; } /* 防止图片溢出 */ #cnblogs_post_body img { max-width: 100%; } /* 文章底部信息 */ .postDesc { margin-top: 0; } /* ********************** * 评论 * **********************/ #comment_form_container .comment_textarea { width: 100%; } .comment_vote { padding-right: 2px; font-size: 14px; margin-top: 10px; } .comment_vote a.comment_digg { color: #f80; } .feedbackItem { margin: 20px 0 25px; background: #fff; padding: 10px 15px; } .feedbackCon { font-size: 13px; border-bottom: 0; padding: 10px 5px 0 5px; text-align: justify; } /* ********************** * 文章评价 * **********************/ #div_digg { position: fixed; right: 30px; bottom: 50px; background: #fff; padding: 20px 20px 15px; border-radius: 5px; border: 1px solid #888; box-shadow: 0 0 0 5px rgba(0, 0, 0, 0.3); } /* ********************** * 隐藏广告 * **********************/ #ad_t2, #opt_under_post, .c_ad_block, #under_post_news, #under_post_kb { display: none !important; } /* ********************** * 适配手机 * **********************/ @media (max-width: 767px) { #home { padding-left: 0; padding-right: 0; } #div_digg { width: auto; padding: 0; right: -25px; bottom: 3px; box-shadow: none; } #div_digg .buryit { display: none; } #mainContent .forFlow { padding-right: 0; } #mainContent .post { padding: 0 20px; } #sideBar, #blog-comments-placeholder { padding: 0 15px; } } /*生成博客目录的CSS*/ #sideBar{ font-size:12px; font-family:Arial, Helvetica, sans-serif; text-align:left; position:fixed;/*将div的位置固定到距离top:50px,right:0px的位置,这样div就会处在最右边的位置,距离顶部50px*/ top:50px; right:0px; width: auto; height: auto; } #sideBarTab{ float:left; width:30px; border:1px solid #e5e5e5; border-right:none; text-align:center; background:#ffffff; } #sideBarContents{ float:left; overflow:auto; overflow-x:hidden;!important; width:200px; min-height:108px; max-height:460px; border:1px solid #e5e5e5; border-right:none; background:#ffffff; } #sideBarContents dl{ margin:0; padding:0; } #sideBarContents dt{ margin-top:5px; margin-left:5px; } #sideBarContents dd, dt { cursor: pointer; } #sideBarContents dd:hover, dt:hover { color:#A7995A; }
02) 博客侧边栏公告(支持HTML代码) (支持 JS 代码)
 
<div class="c-notice"> <div> 这里是你的通告内容 </div> </div> <div class="c-portrait"> <img src="https://pic.cnblogs.com/avatar/1551357/20200522184107.png" alt="" /> <h1><a href="https://www.cnblogs.com/dafei4">飞</a></h1> <h2>飞</h2> <div class="c-social"> </div> </div>
03) 页首 HTML 代码
 
<script type="text/javascript"> /* 功能:生成博客目录的JS工具 测试:IE8,火狐,google测试通过 孤傲苍狼 2014-5-11 */ var BlogDirectory = { /* 获取元素位置,距浏览器左边界的距离(left)和距浏览器上边界的距离(top) */ getElementPosition:function (ele) { var topPosition = 0; var leftPosition = 0; while (ele){ topPosition += ele.offsetTop; leftPosition += ele.offsetLeft; ele = ele.offsetParent; } return {top:topPosition, left:leftPosition}; }, /* 获取滚动条当前位置 */ getScrollBarPosition:function () { var scrollBarPosition = document.body.scrollTop || document.documentElement.scrollTop; return scrollBarPosition; }, /* 移动滚动条,finalPos 为目的位置,internal 为移动速度 */ moveScrollBar:function(finalpos, interval) { //若不支持此方法,则退出 if(!window.scrollTo) { return false; } //窗体滚动时,禁用鼠标滚轮 window.onmousewheel = function(){ return false; }; //清除计时 if (document.body.movement) { clearTimeout(document.body.movement); } var currentpos =BlogDirectory.getScrollBarPosition();//获取滚动条当前位置 var dist = 0; if (currentpos == finalpos) {//到达预定位置,则解禁鼠标滚轮,并退出 window.onmousewheel = function(){ return true; } return true; } if (currentpos < finalpos) {//未到达,则计算下一步所要移动的距离 dist = Math.ceil((finalpos - currentpos)/10); currentpos += dist; } if (currentpos > finalpos) { dist = Math.ceil((currentpos - finalpos)/10); currentpos -= dist; } var scrTop = BlogDirectory.getScrollBarPosition();//获取滚动条当前位置 window.scrollTo(0, currentpos);//移动窗口 if(BlogDirectory.getScrollBarPosition() == scrTop)//若已到底部,则解禁鼠标滚轮,并退出 { window.onmousewheel = function(){ return true; } return true; } //进行下一步移动 var repeat = "BlogDirectory.moveScrollBar(" + finalpos + "," + interval + ")"; document.body.movement = setTimeout(repeat, interval); }, htmlDecode:function (text){ var temp = document.createElement("div"); temp.innerHTML = text; var output = temp.innerText || temp.textContent; temp = null; return output; }, /* 创建博客目录, id表示包含博文正文的 div 容器的 id, mt 和 st 分别表示主标题和次级标题的标签名称(如 H2、H3,大写或小写都可以!), interval 表示移动的速度 */ createBlogDirectory:function (id, mt, st, interval){ //获取博文正文div容器 var elem = document.getElementById(id); if(!elem) return false; //获取div中所有元素结点 var nodes = elem.getElementsByTagName("*"); //创建博客目录的div容器 var divSideBar = document.createElement('DIV'); divSideBar.className = 'sideBar'; divSideBar.setAttribute('id', 'sideBar'); var divSideBarTab = document.createElement('DIV'); divSideBarTab.setAttribute('id', 'sideBarTab'); divSideBar.appendChild(divSideBarTab); var h2 = document.createElement('H2'); divSideBarTab.appendChild(h2); var txt = document.createTextNode('目录导航'); h2.appendChild(txt); var divSideBarContents = document.createElement('DIV'); divSideBarContents.style.display = 'none'; divSideBarContents.setAttribute('id', 'sideBarContents'); divSideBar.appendChild(divSideBarContents); //创建自定义列表 var dlist = document.createElement("dl"); divSideBarContents.appendChild(dlist); var num = 0;//统计找到的mt和st mt = mt.toUpperCase();//转化成大写 st = st.toUpperCase();//转化成大写 //遍历所有元素结点 for(var i=0; i<nodes.length; i++) { if(nodes[i].nodeName == mt|| nodes[i].nodeName == st) { //获取标题文本 var nodetext = nodes[i].innerHTML.replace(/<\/?[^>]+>/g,"");//innerHTML里面的内容可能有HTML标签,所以用正则表达式去除HTML的标签 nodetext = nodetext.replace(/ /ig, "");//替换掉所有的 nodetext = BlogDirectory.htmlDecode(nodetext); //插入锚 nodes[i].setAttribute("id", "blogTitle" + num); var item; switch(nodes[i].nodeName) { case mt: //若为主标题 item = document.createElement("dt"); break; case st: //若为子标题 item = document.createElement("dd"); break; } //创建锚链接 var itemtext = document.createTextNode(nodetext); item.appendChild(itemtext); item.setAttribute("name", num); item.onclick = function(){ //添加鼠标点击触发函数 var pos = BlogDirectory.getElementPosition(document.getElementById("blogTitle" + this.getAttribute("name"))); if(!BlogDirectory.moveScrollBar(pos.top, interval)) return false; }; //将自定义表项加入自定义列表中 dlist.appendChild(item); num++; } } if(num == 0) return false; /*鼠标进入时的事件处理*/ divSideBarTab.onmouseenter = function(){ divSideBarContents.style.display = 'block'; } /*鼠标离开时的事件处理*/ divSideBar.onmouseleave = function() { divSideBarContents.style.display = 'none'; } document.body.appendChild(divSideBar); } }; window.onload=function(){ /*页面加载完成之后生成博客目录*/ BlogDirectory.createBlogDirectory("cnblogs_post_body","h2","h3",20); } </script>
 
 
         
 
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号