|版权声明:本文为博主原创文章,未经博主允许不得转载。

Part.Three中实现了注册和登录的功能,那这一节完成主页内容的填充,并且主页中要实现简单的可以查找代码的功能。

而且有于公共代码部分存储在本机,所以用存储路径的方式存储本地代码的信息。


先写了index.html↓

 {% extends "main.html" %}
 {% block content %}
 <nav class="navbar navbar-default navbar-static-top" role="navigation">
                     <div class="navbar-header">
                         <button type="button" class="navbar-toggle" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1"> <span class="sr-only">Toggle navigation</span><span class="icon-bar"></span><span class="icon-bar"></span><span class="icon-bar"></span></button>                        <a class="navbar-brand" href="#">TSSS</a>
                     </div>
                     <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
                         <ul class="nav navbar-nav">
                             <li>
                                 <a href="/">首页</a>
                             </li>
                             <li>
                                 <a href="/code/list">算法</a>
                             </li>
                             <li class="dropdown">
                                 <a href="#" class="dropdown-toggle" data-toggle="dropdown">代码<strong class="caret"></strong></a>
                                 <ul class="dropdown-menu">
                                     <li>
                                         <a href="https://github.com/MU001999/The-algorithms">GitHub</a>
                                     </li>
                                     <li>
                                         <a href="https://leetcode.com/">LeetCode</a>
                                     </li>
                                     <li>
                                         <a href="https://www.codewars.com/">CodeWars</a>
                                     </li>
                                     <li class="divider">
                                     </li>
                                     <li>
                                         <a href="https://github.com/sxy1001">SXY1001</a>
                                     </li>
                                     <li class="divider">
                                     </li>
                                     <li>
                                         <a href="https://github.com/MU001999">MU001999</a>
                                     </li>
                                 </ul>
                             </li>
                         </ul>
                         <form class="navbar-form navbar-left" role="search" action="/" method="POST">
                             <div class="form-group">
                                 <input type="text" class="form-control" name="codename" />
                             </div> <button type="submit" class="btn btn-default">查找</button>
                         </form>
                         {%if not cookieName%}
                         <ul class="nav navbar-nav navbar-right">
                             <li>
                                 <a href="/sign/in">登入</a>
                             </li>
                             <li>
                                 <a href="/sign/up">注册</a>
                             </li>
                         </ul>
                         {% else %}
                         <ul class="nav navbar-nav navbar-right">
                             <li>
                                 <a href="/user/main">{{ username }}</a>
                             </li>
                             <li class="dropdown">
                                 <a href="#" class="dropdown-toggle" data-toggle="dropdown">更多<strong class="caret"></strong></a>
                                 <ul class="dropdown-menu">
                                     <li>
                                         <a href="/user/main">个人中心</a>
                                     </li>
                                     <li>
                                         <a href="/user/code">我的代码</a>
                                     </li>
                                     <li>
                                         <a href="/user/plan">我的计划</a>
                                     </li>
                                     <li class="divider">
                                     </li>
                                     <li>
                                         <a href="/sign/out">退出登录</a>
                                     </li>
                                 </ul>
                             </li>
                         </ul>
                         {% end %}
                     </div>
                 </nav>
                 <span class="label label-danger">本日最佳</span>
                 <div class="jumbotron well">
                     <h1>
                         Hello, world!
                     </h1>
                     <p>
                         #include &lt;stdio.h&gt;
                     </p>
                     <p>
                         int main()
                     </p>
                     <p>
                         {
                     </p>
                     <p>
                         printf("Hello,World!");
                     </p>
                     <p>
                         return 0;
                     </p>
                     <p>
                         }
                     </p>
                     <p>
                         <a class="btn btn-primary btn-large" href="#">查看讨论</a>
                     </p>
                 </div>
                 <div class="list-group">
                     <a href="#" class="list-group-item active">最新文章</a> {% for blog in blogs %}
                     <div class="list-group-item">
                         <a href="/blog/{{ blog['_id'] }}">{{ blog['title'] }}</a>
                     </div>
                     {% end %}
                 </div>
 {% end %}

↑其中Hello world那部分可以以后根据评论数排序出来的第一个换掉。

再来看一下数据库规范↓

codedb:blogs
	_id 		        ID
	author 		     作者
	title		        题目
	content		内容
	datetime	        时间

然后写IndexHandler↓

 class IndexHandler(web.RequestHandler):
     def get(self):
         coll = self.application.db.blogs
         username = self.get_cookie('username')
         blogs = coll.find().sort('datetime',pymongo.DESCENDING)
         self.('index.html',username=username,blogs=blogs)
     def post(self):
         coll = self.application.db.codes
         codename = self.get_argument('codename')
         codeone = coll.find_one({'title':codename})
         if codeone:
             try:
                 with open(os.path.dirname(__file__),findcode['path'],'r') as f:
                     content = f.read()
                     self.render('code\codeview.html',codeone = codeone)
             except:
                 self.set_status(404)
                 self.write({'error':'code not be here now'})

这样主页的内容就填充完成了。

Python快速建站系列-Part.Four-首页内容填充的更多相关文章

  1. Python快速建站系列-Part.Six-文章内容浏览

    |版权声明:本文为博主原创文章,未经博主允许不得转载. 其实到这里网站的基本功能已经完成一半了,第六节就完成文章内容的阅读功能. 完成blogview.html↓ {% extends "m ...

  2. Python快速建站系列-Part.One-组装开发环境

    |版权声明:本文为博主原创文章,未经博主允许不得转载. 源代码都在github上:SmallStudyStation 现在是个demo,但回来会租个服务器,等功能完善了放到服务器上挂着,域名jusot ...

  3. Python快速建站系列-Part.Three-注册和登录

    |版权声明:本文为博主原创文章,未经博主允许不得转载. 上一个Part已经给TSSS编好了一个简单的Web服务,网页的基础模版也写好了,那从这个Part开始就慢慢增加编写功能. 先写基础功能:注册和登 ...

  4. Python快速建站系列-Part.Two-结构化和布局

    |版权声明:本文为博主原创文章,未经博主允许不得转载. 首先明确我们要建一个什么样的站,作为教程(也算自己使用tornado的一个小总结),自然功能不能太多,但又满足一个普通网站需要的就行了. 目前想 ...

  5. Python快速建站系列-Part.Five.3-个人主页及资料页面

    |版权声明:本文为博主原创文章,未经博主允许不得转载. 第五部分最后一节,完成个人主页里资料页面的个人资料的展示和修改功能,不过毕竟功能比较少,个人资料其实只有昵称一项,手动滑稽. 一如既往先写出来u ...

  6. Python快速建站系列-Part.Five.2-个人主页及文章列表

    |版权声明:本文为博主原创文章,未经博主允许不得转载. 从usercen.html就可以发现我为个人主页设了三个分开的小版面:写文章.个人文章目录.个人资料 所以按顺序Part.Five的第二部分就完 ...

  7. Python快速建站系列-Part.Five.1-个人主页及发表文章

    |版权声明:本文为博主原创文章,未经博主允许不得转载. 现在的TSSS已经有了注册和登录的功能,首页的内容也填充好了,那这一节就完成用户个人主页的内容和发表文章功能的实现. 先完成用户个人主页的use ...

  8. PHPCMS快速建站系列之后台内容自定义修改

    一.后台登录页面 背景图:\statics\images\admin_img 中的 login_bg.jpg 底部版权信息:\phpcms\languages\en 中的 system.lang.ph ...

  9. PHPCMS快速建站系列之类别调用及类别显示页面

    在需要调用类别的地方,比如列表页,首先写循环前面写上一句: <?php $TYPE = getcache('type_content','commons');?> 这句就是把类别缓存加载进 ...

随机推荐

  1. linux 中修改root的密码

    修改root密码 有的时候会出现忘记了root 用户密码的情况,再次我们可以通过进入single(单)用户模式,将root的密码重新设置,然后重启登录即可. 具体流程: 1.先登录root用户(密码已 ...

  2. java判断文件是否存在

    1.判断远程服务器上文件 import java.net.HttpURLConnection; import java.net.URL; public boolean checkRemoteFile( ...

  3. 这世上倒底有没有神仙——说“Excel不是数据库,是不是犯了白马非马论的错误??

    这问题是这样引出来的: 我上计算机应用基础课,讲到Excel,因为一直以来,很多新生对Word中的表格和Excel中的表格总是分不清,甚至有老师也问过我,Excel中的表格和Word中的表格有什么区别 ...

  4. jquery中prop()方法和attr()方法的区别浅析

    官方例举的例子感觉和attr()差不多,也不知道有什么区别,既然有了prop()这个新方法,不可能没用吧,那什么时候该用attr(),什么时候该用prop()呢 jquery1.6中新加了一个方法pr ...

  5. Displaying a full list of groups in Odoo's Kanban view

    Kanban view is probably the most flexible view in Odoo. It can be used for many different purposes. ...

  6. Python的缩进

    关于python的缩进:如果要确认一个函数包含哪些内容,java或php可以使用大括号将函数内容包含起来,但python里没有那样的大括号,python靠“缩进”(四个空格)来确定语句块的始末. 这是 ...

  7. JCreator的配置

    1.在Configure(配置)菜单上选择Options(选项),将弹出对话框. 2.在Option对话框中选择左侧JDK Profile,选择右侧JDK version 1.x.x.. ,点击Edi ...

  8. js 获取中文的拼音

    es6 + 模块化封装 "use strict"; module.exports = { //参数,中文字符串 //返回值:拼音首字母串数组 makePy (str) { if ( ...

  9. iphone6 帶回家”活動!

    十一小長假即將來臨,周向榮還準備窩在家裏坐等“鋒菲戀”的後續結果嗎?雖然宅男無罪,但是請不要繼續在論壇裏高呼“李亞鵬娶了張柏芝”等口號,放下你“不吐槽會死星人”的特質,走出家門去領略一下祖國的大好山河 ...

  10. NLP Deep Learning

    http://blog.csdn.net/itplus http://blog.csdn.net/zouxy09/article/details/8775360