当前位置: 首页 > news >正文

百度推广怎么做网站网站建设中单页源码

百度推广怎么做网站,网站建设中单页源码,提高工作效率总结心得,做虾皮网站作者#xff1a;HelloGitHub-追梦人物文中涉及的示例代码#xff0c;已同步更新到 [HelloGitHub-Team 仓库](https://github.com/HelloGitHub-Team/HelloDjango-blog-tutorial) 博客文章的模型有一个 excerpt 字段#xff0c;这个字段用于存储文章的摘要。目前为止#xff…作者HelloGitHub-追梦人物文中涉及的示例代码已同步更新到 [HelloGitHub-Team 仓库](https://github.com/HelloGitHub-Team/HelloDjango-blog-tutorial) 博客文章的模型有一个 excerpt 字段这个字段用于存储文章的摘要。目前为止还只能在 django admin 后台手动为文章输入摘要。每次手动输入摘要比较麻烦对有些文章来说只要摘取正文的前 N 个字符作为摘要以便提供文章预览就可以了。因此我们来实现如果文章没有输入摘要则自动摘取正文的前 N 个字符作为摘要这有两种实现方法。覆写 save 方法第一种方法是通过覆写模型的 save 方法从正文字段摘取前 N 个字符保存到摘要字段。在 创作后台开启请开始你的表演 中我们提到过 save 方法中执行的是保存模型实例数据到数据库的逻辑因此通过覆写 save 方法在保存数据库前做一些事情比如填充某个缺失字段的值。回顾一下博客文章模型代码blog/models.pyclass Post(models.Model):# 其它字段...body models.TextField()excerpt models.CharField(max_length200, blankTrue)def save(self, *args, **kwargs):self.modified_time timezone.now()super().save(*args, **kwargs)其中 body 字段存储的是正文excerpt 字段用于存储摘要。通过覆写模型的 save 方法在数据被保存到数据库前先从 body 字段摘取 N 个字符保存到 excerpt 字段中从而实现自动摘要的目的。具体代码如下blog/models.pyimport markdown from django.utils.html import strip_tagsclass Post(models.Model):# 其它字段...body models.TextField()excerpt models.CharField(max_length200, blankTrue)# 其它方法...def save(self, *args, **kwargs):self.modified_time timezone.now()# 首先实例化一个 Markdown 类用于渲染 body 的文本。# 由于摘要并不需要生成文章目录所以去掉了目录拓展。md markdown.Markdown(extensions[markdown.extensions.extra,markdown.extensions.codehilite,])# 先将 Markdown 文本渲染成 HTML 文本# strip_tags 去掉 HTML 文本的全部 HTML 标签# 从文本摘取前 54 个字符赋给 excerptself.excerpt strip_tags(md.convert(self.body))[:54]super().save(*args, **kwargs)这里生成摘要的方案是先将 body 中的 Markdown 文本转为 HTML 文本去掉 HTML 文本里的 HTML 标签然后摘取文本的前 54 个字符作为摘要。去掉 HTML 标签的目的是防止前 54 个字符中存在块级 HTML 标签而使得摘要格式比较难看。可以看到很多网站都采用这样一种生成摘要的方式。然后在模板中适当的地方使用模板标签引用 {{ post.excerpt }} 显示摘要的值即可templates/blog/index.htmlarticle classpost post-{{ post.pk }}...div classentry-content clearfixp{{ post.excerpt }}.../pdiv classread-more cl-effect-14a href{{ post.get_absolute_url }} classmore-link继续阅读 span classmeta-nav→/span/a/div/div /article新添加一篇文章这样才能触发 save 方法此前添加的文章不会自动生成摘要要手动保存一下触发 save 方法可以看到摘要效果了。使用 truncatechars 模板过滤器第二种方法是使用 truncatechars 模板过滤器Filter。在 django 的模板系统中模板过滤器的使用语法为 {{ var | filter: arg }}。可以将模板过滤看做一个函数它会作用于被它过滤的模板变量从而改变模板变量的值。例如这里的 truncatechars 过滤器可以截取模板变量值的前 N 个字符显示。关于模板过滤器我们之前使用过 safe 过滤器可以参考 让博客支持 Markdown 语法和代码高亮 这篇文章中对模板过滤器的说明。例如摘要效果需要显示 post.body 的前 54 的字符那么可以在模板中使用 {{ post.body | truncatechars:54 }}。templates/blog/index.htmlarticle classpost post-{{ post.pk }}...div classentry-content clearfixp{{ post.body|truncatechars:54 }}/pdiv classread-more cl-effect-14a href{{ post.get_absolute_url }} classmore-link继续阅读 span classmeta-nav→/span/a/div/div /article不过这种方法的一个缺点就是如果前 54 个字符含有块级 HTML 元素标签的话比如一段代码块会使摘要比较难看。所以推荐使用第一种方法。欢迎关注 HelloGitHub 公众号获取更多开源项目的资料和内容『讲解开源项目系列』启动——让对开源项目感兴趣的人不再畏惧、让开源项目的发起者不再孤单。跟着我们的文章你会发现编程的乐趣、使用和发现参与开源项目如此简单。欢迎联系我们给我们投稿让更多人爱上开源、贡献开源
http://www.yutouwan.com/news/470217/

相关文章:

  • 医疗在线网站建设中国建筑业网
  • 旅游网站需求分析怎么做的怎么做网站然后卖出去
  • 电子商务网站建设与维护第二版珠海建设网站
  • 沧县做网站价格网站做快照怎么做
  • 网站有备案需要什么手续wordpress标签归档
  • 合肥网站建设方案维护正规重庆妇科医院
  • 企业网站优化怎么做网站建设属于硬件还是软件
  • 市北建筑建网站哪家好精品资料网站
  • 建设部作业证件查询官方网站( )是网站可以提供给用户的价值
  • 设计师个人网站主页做网络推广被骗了去哪里投诉
  • 企业网站建设用语网站外包注意事项
  • 二级域名分发网站怎么建立图片的网站
  • 怎么删除织梦做的网站怎样留别人电话在广告上
  • 如何做好区县外宣网站建设wordpress 煎蛋网插件
  • 企业网站开发实训报告旅游网站源码 wordpress模板 v1.0
  • 做百科需要发哪些网站在线设计房屋装修app
  • 做电力的系统集成公司网站网站建设存在四个问题
  • 中国建设银行官网首页 网站全网霸屏整合营销推广
  • 松江九亭网站建设黄埔免费网站建设
  • 做阿里巴巴网站有什么用网站开发与应用 大作业作业
  • 郑州网站建设搭建公司国内最好软件网站建设
  • 河北邢台区号佛山网络排名优化
  • 商城网站建设山西设计网站建设
  • 网站建设公众号小程序开发用vs做网站
  • 到哪查找网站域名做网站专业术语
  • 如何提高网站排名的方法编辑网页的工具有哪些
  • 安庆市城乡建设网站密云网站制作案例
  • 做商城网站外包网站建设-应酷
  • 关键词是网站seo的核心工作wordpress 表单留言
  • 怎么做学校网站和微信公众号wordpress 调用page