From 3a5d6662fbeb80426d9708a5d4684bdd5c1f072f Mon Sep 17 00:00:00 2001 From: inleft <inleft@qq.com> Date: Tue, 02 Aug 2022 17:37:00 +0800 Subject: [PATCH] 优化卡片外链,碎碎念标志 --- src/components/mini/box-new-article.vue | 167 +++++++++++++++++++++++++++++++++++++++---------------- 1 files changed, 117 insertions(+), 50 deletions(-) diff --git a/src/components/mini/box-new-article.vue b/src/components/mini/box-new-article.vue index ebf3225..7c7b909 100644 --- a/src/components/mini/box-new-article.vue +++ b/src/components/mini/box-new-article.vue @@ -1,49 +1,83 @@ <template> - <div> - <div class="recent-posts" id="recent-posts"> - <div class="recent-post-item"> - <div class="miniTag" v-if="isTop==1">置顶</div> - <div class="post_cover left_radius" v-if="index%2==0"> - <router-link :to="{path:'/mdDetail',query:{id:id}}" :title="title"> - <div class="block left_radius"></div> - <img class="post_bg" :src="coverFileURL" :onerror="img404" :alt="title"> - </router-link> - </div> + <div class="recent-posts" id="recent-posts"> + <div class="recent-post-item"> + <div class="miniTag" v-if="isTop==1">置顶</div> + <div class="post_cover left_radius" v-if="index%2==0"> - <div class="post_cover right_radius" v-else> - <router-link :to="{path:'/mdDetail',query:{id:id}}" :title="title"> - <div class="block right_radius"></div> - <img class="post_bg" :src="coverFileURL" :onerror="img404" :alt="title"> - <!-- <img class="post_bg" src="https://unpkg.zhimg.com/ahzo@1.0.3/blogpic/1.jpg" onerror="this.onerror=null,this.src="/img/404.jpg"" :alt="title"> --> - </router-link> - </div> + <a :href="jumpURL" target="_blank" class="no-underline" v-if="articleFileType==5" + @click="showMsg(articleFileType,jumpURL)"> + <div class="block left_radius"></div> + <img class="post_bg" :src="coverFileURL" :onerror="img404" :alt="title"> + </a> + <router-link :to="{path:'/mdDetail',query:{id:id}}" :title="title" v-else> + <div class="block left_radius"></div> + <img class="post_bg" :src="coverFileURL" :onerror="img404" :alt="title"> + </router-link> + </div> - <div class="recent-post-info"> - <router-link :to="{path:'/mdDetail',query:{id:id}}" class="article-title"> - <a-icon type="lock" style="color:rgba(0,0,0,.25)" v-if="authStatus==3" /> - <a-icon type="stop" style="color:rgba(0,0,0,.25)" v-if="authStatus==2" /> - {{title}} - </router-link> - <!-- <a class="article-title" href="/mdDetail" :title="title"> {{title}}</a> --> - <div class="article-meta-wrap" style="display: flex;"> - <span class="post-meta-date"> - <a-icon type="calendar" /> - <span class="article-meta-label"></span> - <time datetime="2022-01-13T06:25:00.000Z" - title=" 2022-01-13 14:25:00">{{publishDate}}</time> + <div class="post_cover right_radius" v-else> + <a :href="jumpURL" target="_blank" class="no-underline" v-if="articleFileType==5" + @click="showMsg(articleFileType,jumpURL)"> + <div class="block left_radius"></div> + <img class="post_bg" :src="coverFileURL" :onerror="img404" :alt="title"> + </a> + <router-link :to="{path:'/mdDetail',query:{id:id}}" :title="title" v-else> + <div class="block right_radius"></div> + <img class="post_bg" :src="coverFileURL" :onerror="img404" :alt="title"> + <!-- <img class="post_bg" src="https://unpkg.zhimg.com/ahzo@1.0.3/blogpic/1.jpg" onerror="this.onerror=null,this.src="/img/404.jpg"" :alt="title"> --> + </router-link> + </div> + + <div class="recent-post-info"> + + <a :href="jumpURL" target="_blank" class="article-title" v-if="articleFileType==5" + @click="showMsg(articleFileType,jumpURL)"> + <a-icon type="lock" style="color:rgba(0,0,0,.25)" v-if="authStatus==3" /> + <a-icon type="stop" style="color:rgba(0,0,0,.25)" v-if="authStatus==2" /> + {{title}} + <a-badge :count="1" dot v-if="isAnyUpdate==1" title="最近有更新"></a-badge> + </a> + + <router-link :to="{path:'/mdDetail',query:{id:id}}" class="article-title" v-else> + <a-icon type="lock" style="color:rgba(0,0,0,.25)" v-if="authStatus==3" /> + <a-icon type="stop" style="color:rgba(0,0,0,.25)" v-if="authStatus==2" /> + {{title}} + <a-badge :count="1" dot v-if="isAnyUpdate==1" title="最近有更新"></a-badge> + </router-link> + <!-- <a class="article-title" href="/mdDetail" :title="title"> {{title}}</a> --> + <div class="article-meta-wrap" style="display: flex;"> + <span class="post-meta-date"> + <a-icon type="calendar" /> + <span class="article-meta-label"></span> + <time datetime="2022-01-13T06:25:00.000Z" title=" 2022-01-13 14:25:00"> {{publishDate}} </time> + </span> + <span class="article-meta__separator" style="margin: 0px 3px ;"> | </span> + + <span class="article-meta"> + <a-icon type="book" /> + <router-link :to="{path:'/articleList',query:{typeId:articleTypeId}}" + class="article-meta__categories"> {{articleTypeName}}</router-link> + <span v-if="articleFileType==5"> + <span v-if="jumpURL !=null && jumpURL!=''"> + <span class="article-meta__separator" style="margin: 0px 3px ;">|</span> + <span class="post-meta-date"> + <a-icon type="share-alt" /> + <a :href="jumpURL" target="_blank" class="no-underline"> 外链 </a> + </span> + </span> + + <span v-else> + <span class="article-meta__separator" style="margin: 0px 3px ;">|</span> + <span class="post-meta-date"> + <a-icon type="thunderbolt" />碎碎念 + </span> + </span> </span> - <span class="article-meta__separator" style="margin: 0px 3px ;"> | </span> - <span class="article-meta"> - <a-icon type="book" /> - <router-link :to="{path:'/mdDetail',query:{id:id}}" class="article-meta__categories"> - {{articleTypeName}} - </router-link> - <!-- <a class="article-meta__categories" href="#"> {{tag}}</a> --> - </span> - </div> - <div class="content"> - {{introduce}} - </div> + <!-- <a class="article-meta__categories" href="#"> {{tag}}</a> --> + </span> + </div> + <div class="content"> + {{introduce}} </div> </div> </div> @@ -51,12 +85,31 @@ </template> <script> + import { + NotificationOutlined + } from '@ant-design/icons-vue'; + export default { + methods: { + showMsg(articleFileType, jumpURL) { + if (articleFileType == 5 && (jumpURL == null || jumpURL == "")) { + this.$message.info('这只是一句碎碎念,没有更多内容啦', 3); + return + } + } + }, + components: { + NotificationOutlined + }, props: { "index": { default: 0, - },"id": { + }, + "id": { default: 0, + }, + "articleTypeId": { + default: null }, "isTop": { default: 0, @@ -76,17 +129,25 @@ "publishDate": { default: "", }, + "updateDate": { + default: "", + }, "coverFileURL": { + default: "", + }, + "isAnyUpdate": { + default: "", + }, + "articleFileType": { + default: 1, + }, + "jumpURL": { default: "", } }, data() { return { - img404: "this.onerror='';this.src=\"https://unpkg.zhimg.com/ahzo@1.0.3/blogpic/1.jpg\"", - // "title": "使用KeyStore生成证书", - // "publishTime": "2022-01-14", - // "tag": "随手记", - // "content": "前言Keytool是一个Java数据证书的管理工具 , 在keystore里,包含两种数据: 密钥实体(Key entity):即密钥(secret key)又或者是私钥和配对公钥(采用非对称加密) 可信任的证书实体(trusted certificate entries):即证书(包含公钥) keytool常用命令: genkey 在用户主目录中创建一个默认文件”.keystore” alias 产生别名 keystore 指定密钥库的名称(产生的各类信息将不在.keystore文件中) keyalg 指定密钥的算法 (如 RSA DSA(如果不指定默认采用DSA)) validity 指定创建的证书有效期多少天 keysize 指定密钥长度 storepass 指定密钥库的密码(获取keystore信息所需的密码) keypass 指定别名条目的密码(私钥的密码) dname 指定证书拥有者信息 例如: “CN=名字与姓氏,OU=组织单位名称,O=组织名称,L=城市或区域名称,ST=州或省份名称,C=单位的两字母国家代码 list 显示密钥库中的证书信息 keytool - ..." + img404: "this.onerror='';this.src=\"http://t.inleft.com/share/media_photo/1.jpg\"", } } } @@ -104,6 +165,10 @@ .recent-post-item { position: relative; + + a { + position: initial; + } } .miniTag { @@ -198,9 +263,10 @@ } #recent-posts>.recent-post-item .post_cover { - width: 33%; - position: sticky; + // position: sticky; + position: inherit; + width: 33%; opacity: .8; padding: calc(1.2rem * @ahzoo-proportion) calc(0.2rem * @ahzoo-proportion); overflow: hidden; @@ -301,6 +367,7 @@ order: 3; color: #858585; font-size: 90%; + flex-wrap: wrap; .article-meta-label { padding-right: 0.2rem; -- Gitblit v1.9.1