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

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. Selenium_Selenium WebDriver 中鼠标和键盘事件分析及扩展

    在使用 Selenium WebDriver 做自动化测试的时候,会经常模拟鼠标和键盘的一些行为.比如使用鼠标单击.双击.右击.拖拽等动作:或者键盘输入.快捷键使用.组合键使用等模拟键盘的操作.在 W ...

  2. thinkphp添加空数据的解决办法

    thinkphp真是个麻烦的东西,各种小问题,其中字段映射的表单名不能与数据库的字段名称相同,否则会添加空数据! 还有自动完成的名称要与字段映射后的名称相同,否则自动完成不会起作用! 还有自动验证的字 ...

  3. Quartz.net 的简单使用,创建定时任务

    ISchedulerFactory sf = new StdSchedulerFactory(); sched = sf.GetScheduler(); JobDetail job = new Job ...

  4. Server Error in '/' Application

    在服务器部署了网站,然后访问的时候出现异常   Server Error in '/' Application,一般这样的异常都是不明确的,我们应当把网站根目录web.config<custom ...

  5. 当session过期后自动跳转到登陆页而且会跳出iframe框架

    写项目时在重定向后一直存在一个问题就是重定向后登陆页面会出现在跳出的子框架里.

  6. bzoj4514: [Sdoi2016]数字配对--费用流

    看了一眼题目&数据范围,觉得应该是带下界的费用流 原来想拆点变成二分图,能配对的连边,跑二分图,可行性未知 后来看到另外一种解法.. 符合匹配要求的数要满足:质因子的个数相差为1,且两者可整除 ...

  7. Cocos2d-x 3.4环境安装

    电脑系统window7 32位 1.首先从官网下载cocos2d-x并解压 http://cn.cocos2d-x.org/download/ 解压后的文件夹中有一个setup.py,双击运行.需要安 ...

  8. Python 文件编码(文件乱码)

    IndentationError: unindent does not match any outer indentation level 文件未对齐,在记事本打开. 乱码原因:源码文件的编码格式为u ...

  9. 百度Site App的uaredirect.js实现手机访问,自动跳转网站手机版

    以下为代码,可放置在网站foot底部文件,或者haead顶部文件,建议将代码放在网站顶部,这样可以实现手机访问立即跳转! <script src="http://siteapp.bai ...

  10. Android课程---视图组件总结