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

安徽索凯特建设工程有限公司网站南宁开发公司

安徽索凯特建设工程有限公司网站,南宁开发公司,开发网站的申请怎么写,设计网站专业文章目录0.思路引导1.方法一#xff1a;覆写 save 方法2.方法二#xff1a;使用 truncatechars 模板过滤器0.思路引导 博客文章的模型有一个 excerpt 字段#xff0c;这个字段用于存储文章的摘要。 若在 django admin 后台手动为文章输入摘要#xff0c;每次手动输入摘要… 文章目录0.思路引导1.方法一覆写 save 方法2.方法二使用 truncatechars 模板过滤器0.思路引导 博客文章的模型有一个 excerpt 字段这个字段用于存储文章的摘要。 若在 django admin 后台手动为文章输入摘要每次手动输入摘要比较麻烦。 若想要程序自动摘取正文的前 N 个字符作为摘要以便提供文章预览就可以了。 因此我们来实现如果文章没有输入摘要则自动摘取正文的前 N 个字符作为摘要。 1.方法一覆写 save 方法 第一种方法是通过覆写模型的 save方法从正文body 中摘取前 N 个字符保存到摘要字段。 save方法中执行的是保存模型实例数据到数据库的逻辑因此通过覆写 save 方法在保存数据库前做一些事情比如填充某个缺失字段的值。 方案先将 body 中的 Markdown 文本转为 HTML 文本去掉 HTML 文本里的 HTML 标签然后摘取文本的前 54 个字符作为摘要。去掉 HTML 标签的目的是防止前 54 个字符中存在块级 HTML 标签而使得摘要格式比较难看。可以看到很多网站都采用这样一种生成摘要的方式。 代码位置blog/models.py import 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)然后在模板中适当的地方使用模板标签引用 {{ post.excerpt }} 显示摘要的值即可 文件位置templates/blog/index.html article 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 方法可以看到摘要效果如下 2.方法二使用 truncatechars 模板过滤器 在 django 的模板系统中我们之前使用过 safe 过滤器使用语法为 {{ var | filter: arg }}。可以将模板过滤看做一个函数它会作用于被它过滤的模板变量从而改变模板变量的值。 第二种方法是使用 truncatechars 模板过滤器Filter其可以截取模板变量值的前 N 个字符显示。 例如摘要效果需要显示 post.body 的前 54 的字符那么可以在模板中使用 {{ post.body | truncatechars:54 }}。 文件位置templates/blog/index.html article 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 元素标签的话比如一段代码块会使摘要比较难看。所以推荐使用第一种方法。
http://www.zqtcl.cn/news/836895/

相关文章:

  • 工作室 网站建设app公司
  • 自己做的网站怎么在百度搜索到网页制作论文3000字
  • 如何网站托管中国跨境电商平台有多少
  • 手机p2p网站做平面设计兼职的网站有哪些
  • 贵金属网站建设唐山网站制作工具
  • 网站入门成都网站制作沈阳
  • 接做网站单子的网站做网站要会那些ps
  • 做盗市相关网站wordpress速度优化简书
  • 贵阳手机网站建设公司国内永久免费云服务器
  • 温州做网站定制哪家网络推广公司好
  • 招聘网站怎么做线下活动网站后台管理系统怎么开发
  • 西湖区外贸网站建设商梦建站
  • 网站首页设计注意斗蟋蟀网站建设
  • 石家庄网站建设远策科技网站建设公司人员配备
  • 手机怎么建网站链接专门做鞋子的网站吗
  • 网站建设设计作品怎么写网站建设 网站内容 采集
  • 自己做网站nas如何做网站大图片
  • 网站优化定做嘉兴模板建站代理
  • 南宁做网站比较好的公司有哪些花乡科技园区网站建设
  • 网站注册平台怎么注册申请空间 建立网站吗
  • 汕头住房与城乡建设网站做网站视频 上传到哪儿
  • 东莞网站关键词优化福建个人网站备案
  • 国外获奖flash网站泉州网站制作专业
  • 万网域名注册后如何做网站教学上海app开发和制作公司
  • 恩施网站建设公司个人网站怎么制作成图片
  • 泸州高端网站建设公司上海企业网站
  • wordpress 建站 知乎济南全包圆装修400电话
  • 织梦建设两个网站 视频影视公司宣传片
  • 北京小企业网站建设那个做网站好
  • 怎样用模块做网站深圳网站建设制作厂家