开发项目前端的主要工作目录

在开发项目中前端往往会做很多的事情,特别是对于一个大型的项目的研发,下面是本人在一个自主创建的一个开发小组(自主研发开发框架)里面做前端的一些心得和主要工作内容。

分为以下几部:

第一、clone git

通过gitcafe上面clone下来的documentation文件夹,在里面打开原型设计,开始编写静态网页。

第二、建立开发框架上的文件夹

在自己的项目目录下面建立几个与前端相关的文件夹,包括:

moders  >>写一些后端所需要的模型,在后端封装一个对象的时候需要用到。

static     >>写一些静态文件,比如css、js、images、file...

template >>在pages写好以后,需要改模板,这样后端才能认识,具体的改发还要看后端是什么语言。

pagetest  >>写一些前端的测试文件,相当于模拟一个后端。

pages     >>拿到原型设计以后写的静态html文件放在此处。

第三、写静态页面

开始写静态页面,放在pages文件下面,主要用于平面设计的css最初的修改。在编写html文件的过程中,注意尽量做到每一个标签、按钮都加上ID和name,便于后端的自动化测试和平面设计的界面优化(直接在css文件里面写对应的css即可);

静态页面写好以后,需要加上一些css或者js,最好是采用外联的文件,对应的css写在/static/css/或/static/js文件夹中便于管理。

第四、修改模板

在第三步写好了静态html文件以后,还需要把静态页面修改为模板,修改的方式有很多,可以参考:

http://my.oschina.net/jiemachina/blog/205416

第五:前端测试

 前端的单元测试是特别重要的一步,如果没有进行测试就提交代码的话会让后端的集成测试的别多bug,而且做完前端的单元测试也会对后端有一定的理解,自己也能明白怎么一回事。所谓前端的单元测试呢,就是模拟一个后端,将前端的代码嵌套到后端去。具体做法如下(后端为python tonador):

下面是前端测试的主文件pagetestmain.py,测试时需要启动该文件,命令(在你确定安装了python的情况下):python3 pagetestmain.py。

 1 # 此文件为前端单元测试启动文件
 2 
 3 import os.path
 4 import uuid
 5 import tornado.ioloop
 6 import tornado.web
 7 from tornado.options import define, options
 8 
 9 #-----------------不同功能的测试放到pagetest目录的不同文件中,并在此引入
10 from pagetest import pagestest
11 
12 
13 define("port", default=9003, help="run on the given port", type=int)
14 
15 
16 class Application(tornado.web.Application):
17 
18     def __init__(self):
19         handlers = [
20             (r"/user_login_temp", pagestest.Userloginrpl),    #在此处添加路由
21           
22         ]  # 在此列表中追加新的路由cal
23         settings = dict(
24             cookie_secret=str(uuid.uuid4()),
25             template_path=os.path.join(os.path.dirname(__file__), "templates"),
26             static_path=os.path.join(os.path.dirname(__file__), "static"),
27             xsrf_cookies=True,
28             login_url="/",
29             debug=True
30         )
31         tornado.web.Application.__init__(self, handlers, **settings)
32 
33 
34 if __name__ == "__main__":
35     app = Application()
36     app.listen(options.port)
37     tornado.ioloop.IOLoop.current().start()

然后在pagestest.py里面添加路由对应的类:

1 import json
2 import tornado.web
3 from models import books    #在外面引用的模型
4 
5 
6 class Userloginrpl(tornado.web.RequestHandler):
7 
8     def get(self):
9         self.render("User_login.html")    #读模板

针对于前端的测试,一般分为两种,一种是selft.render(""):读模板,另外一种是self.write(""):写回操作信息,或者其他返回信息;

在读模板的过程中要把模板上所有的变量都赋值,至于for循环的需要用列表去查看models里面的对应模型文件来写如下:

首先HTNL文件(改好的模板)里面的for循环:

1   {%for account in accountlist%}
2 <option value="{{account.account_name}}" name="acc_name2" title="{{account.account_name}}({{account.account_nickname}}" >
3 {{account.account_name}}({{account.account_nickname}})
4 </option>
5     {%end%}

models文件夹里面的模型文件account.py:

 1 class Account:
 2 
 3     def __init__(self, account_id, account_name, account_nickname):
 4         self.account_id = account_id
 5         self.account_name = account_name
 6         self.account_nickname = account_nickname
 7 
 8     def __str__(self):
 9         return str(self.account_id) + "#" + \
10             str(self.account_name) + "#" + \
11             str(self.account_nickname) 
12 
13     def objtodict(self):
14         return {'account_id': self.account_id,
15                 'account_name': self.account_name,
16                 'account_nickname': self.account_nickname
17                 }

同样的方法在pagetestmain.py里面添加路由:

 1 # 此文件为前端单元测试启动文件
 2 
 3 import os.path
 4 import uuid
 5 import tornado.ioloop
 6 import tornado.web
 7 from tornado.options import define, options
 8 
 9 #-----------------不同功能的测试放到pagetest目录的不同文件中,并在此引入
10 from pagetest import pagestest
11 
12 
13 define("port", default=9003, help="run on the given port", type=int)
14 
15 
16 class Application(tornado.web.Application):
17 
18     def __init__(self):
19         handlers = [
20             (r"/user_login_temp", pagestest.Userloginrpl),
21             (r"/manage_account_temp", pagestest.Manageaccountrpl),
22           
23         ]  # 在此列表中追加新的路由cal
24         settings = dict(
25             cookie_secret=str(uuid.uuid4()),
26             template_path=os.path.join(os.path.dirname(__file__), "templates"),
27             static_path=os.path.join(os.path.dirname(__file__), "static"),
28             xsrf_cookies=True,
29             login_url="/",
30             debug=True
31         )
32         tornado.web.Application.__init__(self, handlers, **settings)
33 
34 
35 if __name__ == "__main__":
36     app = Application()
37     app.listen(options.port)
38     tornado.ioloop.IOLoop.current().start()

然后在pagestest.py里面加上该路由对应的类名:

class Manageaccountrpl(tornado.web.RequestHandler):

    def get(self):
        
        accountlist = [account.Account(
            "1", "李四", "lisi"), account.Account(
            "2", "张三", "zhangsan"), account.Account(
            "3", "王三", "wangsan"),account.Account(
            ]
        self.render(
            "Manage_account.html", accountlist=accountlist)

如果是ajax对应的操作路径的话,当然也需要在主函数里面加上路径,pagestest.py里面的类不一样:

1 class Addaccountrpl(tornado.web.RequestHandler):
2 
3     def post(self):
4         acc_reson = self.get_argument("acc_reson")
5         print(acc_reson)
6         obj = {
7             "returnedjson": {"infostatus": "T", "infomsg": "添加成功"}}
8         a = json.dumps(obj)
9         self.write(a)

这样在返回给ajax回显到页面上提醒用户。

 

第六、测试完成,提交代码

把前端对应的文件提交到git服务器上去,以便后端可以去克隆。提交完成以后发卡片给后端,让其完成相应的工作内容。

posted @ 2015-10-24 22:16  纸鸢&红豆·绿豆  阅读(1029)  评论(0编辑  收藏  举报