沉思语录

取次花丛懒回顾,半缘修道半缘君


  • 首页

  • 归档

  • 标签

  • 搜索

Django

发表于 2017-04-15 |

开发过程

新建一个app之后,在settings.py的INSTALLED_APPS中需要注册一下这个APP

模板的配置

在app的目录下面新建一个tempaltes的目录
在base_dir/app_name/templates/app_name/xxx.html这个目录下面去写html
然后在setting.py的TEMPLATES的’DIRS’加上,[os.path.join(BASE_DIR, app_name, ‘templates’),
这样在app下面的views里面就可以render这个html了,然后在url里面做配置

静态文件的配置

在app的目录下面新建一个static的目录
在base_dir/app_name/static/app_name/目录下面去建imgaes,css,js等目录
在下面摆放静态文件
在settings.py按照模板配置

集成ajax

主要是要注意:在用ajax提交表单的时候,需要在header中包含进csrf-token

集成reactjs

Django默认使用的templates比较适合用在静态页面(页面不太变化的场景下面),所有的html中的数据都通过context传进去。
Reactjs则比较适合用在动态页面中,一般会在项目的根目录下建立一个目录(front)专门用于储存reactjs的代码,同时将reactjs的code经过webpack之后的代码放入另一个目录中(webpack)。在Django的setting中static文件需要包含从这个webpack目录中去找。
在Django的html文件中:1.需要包含reactjs渲染的主块 2.另外reactjs的代码express中是通过script包含进去的,在django中则是使用django webpack load去包含进去。

同时在webpack中可以配置生成的文件用hash之后的名字命名。这样在生产环境中可以避免浏览器缓存的问题,就是浏览器缓存了上一版本的js文件,用hash之后的文件名就会重新加载。webpack会生成一个json文件,里面包含了webpack前后的文件名的对应关系,这样在html中引入webpack之后的hash名的js文件的时候,就不需要没有刺激都修改引入的文件名了。
比如:通过webpack-bundle-tracker会写入webpack-stats.json文件中

  1. python manage.py runserver 来启动django
  2. 敲gulp 来生成babel和webpack的文件
  3. webpack配置webpack-bundle-tracker来生成webpack-stats.json文件

部署

部署到阿里云上,创建好数据库之后,启动,会报错说数据表不存在,python manager.py makemigrations 也会报同样的错
有两种可能的解决方法:

  1. 数据迁移
    把开发环境中的数据都迁移到云端,mysql比较方便,用冷迁移就可以了
    备份数据: mysqldump -u root -p databaseName > data.sql
    恢复: mysqldump -u root -p databaseName < data.sql

当然mysql也支持数据的热备份,只需要在mysql中配置就可以了,本质上就是在A服务器上对数据库操作的sql语句会备份在一个log文件中,B服务器会监听这个log文件,实时更新到本地,并执行对应的sql语句

  1. 将各个APP下面的migration文件夹中的00x开头的记录django数据model变化的文件删除,然后重新migrate一下

Python_CookBook

发表于 2017-04-15 |

介绍

最近在读cookbook, 记录一下阅读的心得
总的感觉是书上介绍的很多用法都很精妙,有些方法也非常实用
第一遍读下来还有很多高级的用法看得不是很明白,需要多写,多读源码
在实践中去掌握这些写法和用法
里面还是也很多的用法不熟悉,还需要好好努力!

黄山游记

发表于 2017-03-06 |

黄山游记

记录一趟短途的出行 2017.2.26 - 2017.2.28 游历黄山

日落

2017.2.27日 黄山 丹霞峰上观看落日
丹霞峰落日

阅读全文 »
1…262728
Leslie

Leslie

记录心情与能力的成长

82 日志
15 标签
© 2021 Leslie
由 Hexo 强力驱动
主题 - NexT.Pisces
本站访客数 本站总访问量