xadmin引入样式无效
当使用下面方式引入xadmin样式的时候发现并没有效果:
file:adminx.py
xadminxadmin views BaseSetting(): enable_themes = use_bootswatch = Some Codes...xadmin.site.register(views.CommAdminViewGlobalSettings)
file:__init__.py
default_app_config = "users.apps.UsersConfig"
错误原因:
当use_bootswatch 为True的时候,就会使用httplib2去
http://bootswatch.com/api/3.json
网址获取主题菜单项。但是使用浏览器打开这个网址,http会被替换成https的。httplib2访问这个https的网址,就会报错。报错信息为:
[SSL: SSLV3_ALERT_HANDSHAKE_FAILURE] sslv3 alert handshake failure
这边使用requests库来替代httplib2.
在xadmin的源码目录下修改xadmin\plugins\themes.py:
#coding:utf-8from __future__ import print_functionimport httplib2from django.template import loaderfrom django.core.cache import cachefrom django.utils import sixfrom django.utils.translation import ugettext as _from xadmin.sites import sitefrom xadmin.models import UserSettingsfrom xadmin.views import BaseAdminPlugin, BaseAdminViewfrom xadmin.util import static, jsonimport sixif six.PY2: import urllibelse: import urllib.parseimport requestsTHEME_CACHE_KEY = 'xadmin_themes' class ThemePlugin(BaseAdminPlugin): enable_themes = False # {'name': 'Blank Theme', 'description': '...', 'css': 'http://...', 'thumbnail': '...'} user_themes = None use_bootswatch = False default_theme = static('xadmin/css/themes/bootstrap-xadmin.css') bootstrap2_theme = static('xadmin/css/themes/bootstrap-theme.css') def init_request(self, *args, **kwargs): return self.enable_themes def _get_theme(self): if self.user: try: return UserSettings.objects.get(user=self.user, key="site-theme").value except Exception: pass if '_theme' in self.request.COOKIES: if six.PY2: func = urllib.unquote else: func = urllib.parse.unquote return func(self.request.COOKIES['_theme']) return self.default_theme def get_context(self, context): context['site_theme'] = self._get_theme() return context # Media def get_media(self, media): return media + self.vendor('jquery-ui-effect.js', 'xadmin.plugin.themes.js') # Block Views def block_top_navmenu(self, context, nodes): themes = [ {'name': _(u"Default"), 'description': _(u"Default bootstrap theme"), 'css': self.default_theme}, {'name': _(u"Bootstrap2"), 'description': _(u"Bootstrap 2.x theme"), 'css': self.bootstrap2_theme}, ] select_css = context.get('site_theme', self.default_theme) if self.user_themes: themes.extend(self.user_themes) if self.use_bootswatch: ex_themes = cache.get(THEME_CACHE_KEY) if ex_themes: themes.extend(json.loads(ex_themes)) else: ex_themes = [] try: # h = httplib2.Http() # resp, content = h.request("https://bootswatch.com/api/3.json", 'GET', '', # headers={"Accept": "application/json", "User-Agent": self.request.META['HTTP_USER_AGENT']}) # if six.PY3: # content = content.decode() # watch_themes = json.loads(content)['themes'] # ex_themes.extend([ # {'name': t['name'], 'description': t['description'], # 'css': t['cssMin'], 'thumbnail': t['thumbnail']} # for t in watch_themes]) flag = False # 假如为True使用原来的代码,假如为Flase,使用requests库来访问 if flag: h = httplib2.Http() resp, content = h.request("http://bootswatch.com/api/3.json", 'GET', '', headers={"Accept": "application/json", "User-Agent": self.request.META['HTTP_USER_AGENT']}) if six.PY3: content = content.decode() watch_themes = json.loads(content)['themes'] else: content = requests.get("https://bootswatch.com/api/3.json") if six.PY3: content = content.text.decode() watch_themes = json.loads(content.text)['themes'] ex_themes.extend([ {'name': t['name'], 'description': t['description'], 'css': t['cssMin'], 'thumbnail': t['thumbnail']} for t in watch_themes]) except Exception as e: print(e) cache.set(THEME_CACHE_KEY, json.dumps(ex_themes), 24 * 3600) themes.extend(ex_themes) nodes.append(loader.render_to_string('xadmin/blocks/comm.top.theme.html', {'themes': themes, 'select_css': select_css})) site.register_plugin(ThemePlugin, BaseAdminView)
然后就可以调出企业常用的各种主题样式了。
转载于:https://blog.51cto.com/xvjunjie/2084672
xadmin引入样式无效相关推荐
- vue scoped html样式无效
1.问题场景 page1,page2都使用flexible移动端自适应的时候,有一个页面page2需要手动设置rem基准值, //手动设置基准 html{ font-size: 120px !impo ...
- Vue的v-html样式无效问题
## 例如我在vue中添加了如下的v-html: 样式无效代码: <table class="table" v-html="table_data" wid ...
- (javascript)vue项目打包后,写的覆盖element的样式无效了。这是什么原因?
问题: (javascript)vue项目打包后,写的覆盖element的样式无效了.这是什么原因?描述: 在开发模式模式下,写的覆盖样式都有效,打包后就无效,请问下是什么原因? main.js里的c ...
- 织梦channel标签currentstyle样式无效不起作用
我们在用织梦系统制作网站时,经常会用到channel标签来调子栏目.但是,很多朋友会遇到这种情况在使用channel标签来调子栏目的时候,指定 "type=son typeid=x" ...
- Canvas设置样式无效导致圆变成椭圆的问题研究剖析
Canvas设置样式无效导致圆变成椭圆的问题研究剖析,如下面代码段. <!DOCTYPE html> <html lang="en"> <head&g ...
- 解决ant design vue中的modal弹框样式修改无效问题 修改modal样式无效
ant design vue中的modal弹框修改样式无效问题 ant中的弹框样式是修改不了的 原因在于弹框modal被挂载在最大的元素div外面了 所以需要将挂载在某个html元素上 在modal外 ...
- 修改elementUI组件样式无效的多种解决方式
前言:vue+elementUI项目开发中,经常遇到修改elementUI组件样式无效的问题, 原因:在vue组件中我们经常需要给style添加scoped来使得当前样式只作用于当前组件的节点.添加s ...
- Django xadmin引入DjangoUeditor
Django xadmin引入DjangoUeditor 版本:python3.6.1,Django1.11.1 DjangoUeditor下载地址:https://github.com/twz915 ...
- antd mysql_create-react-app使用antd按需加载的样式无效问题的解决
官网给出的按需加载解决方案,先安装 babel-plugin-import 因为antd默认引入样式是less,所以需要手动配置为CSS,配置方法如下: 第一种方法:在package.json中配置, ...
最新文章
- html web上传文件原理,Web上传文件的原理及实现
- R语言ggplot2可视化绘制线图(line plot)、使用gghighlight包突出高亮线图的满足条件的线图、设置高亮线图不显示默认自动显示的文本标签(use_direct_label)
- app息屏后ajax请求不执行_息屏时钟app下载-息屏时钟软件下载v1.0 安卓版
- mysql insert报错_mysql数据库使用insert语句插入中文数据报错
- python中类的方法里面变量前加self与不加self的区别
- c++ 构造函数数组_“动态数组”的设计与实现
- ~~朴素筛法求素数(附模板题)
- Codevs 均分纸牌(贪心)
- JS Array 对象常用方法 unshift / push 、shift / pop 、filter() / map()
- 黑马旅游网---day1
- 订单参数异常,请重新下单后再发起付款。(ALIN42682)
- 自动点击android按钮,Android实现自动点击无障碍服务功能的实例代码
- 明哥手把手《闲鱼快速入门指南》电子书!!
- U盘系统、格式化等问题的解决办法
- 火车票分段分批放票的时间
- 【Redis学习】:string数据类型详解
- Pycharm如何将项目部署到树莓派上?
- 树莓派与windows之间传输文件
- 人工智能+名片,我们看到了营销圈中的“阿尔法
- python dataframe是什么_什么是Pandas的DataFrame?