首页 > 其他分享 >django simpleui 的list_display添加自定义列、显示图片 及alert弹窗的设置方法

django simpleui 的list_display添加自定义列、显示图片 及alert弹窗的设置方法

时间:2024-04-10 20:59:36浏览次数:41  
标签:obj name 自定义 admin list django display verbose

参考django simpleui 的list_display添加自定义列、显示图片 及alert弹窗的设置方法-CSDN博客

环境:
python: 3.8.x
Django: 3.2.x
Django-simpleui: 2021.x


先定义下模型

#models.py

class Dog(models.Model):
    name = models.CharField(max_length=15, verbose_name='小狗名字')
    age = models.IntegerField(verbose_name='小狗年龄', default=0)
    # settings已经设置过 MEDIA_ROOT 和 MEDIR_URL
    icon = models.ImageField(upload_to='icon/', verbose_name='小狗头像')

    class Meta:
        db_table = 'tb_dog'
        verbose_name = '狗狗'
        verbose_name_plural = verbose_name

    def __str__(self):
        return self.name

 

Admin设置

from django.utils.safestring import mark_safe

@admin.register(Dog)
class DogAdmin(admin.ModelAdmin):
    list_display = ('img', 'name', 'age', 'operate')
    list_display_links = ('name',)

    # 在list页面显示头像
    @admin.display(description='头像', ordering='name')
    def img(self, obj):
        div = f"<img src='{obj.icon.url}' width='32px'>"
        return mark_safe(div)

    # 定义一些操作示例
    @admin.display(description='操作', ordering='name')
    def operate(self, obj):
        info_msg = f'这条狗的名字是:{obj.name} 年龄是:{obj.age}'
        # simpleui 用的elementui ,可以使用el的类修改默认样式
        btn1 = f"""<button οnclick="self.parent.app.$msgbox('{info_msg}')"
                            class="el-button el-button--warning el-button--small">信息</button>"""
        # 在新标签中打开修改界面,url可以随意指定。自己可以多做尝试
        data = '{"name": "%s", "icon": "fas fa-user-tie", "url": "/admin/app1/dog/%d/change/"}' % (obj.name, obj.pk)
        btn2 = f"""<button οnclick='self.parent.app.openTab({data})'
                             class='el-button el-button--danger el-button--small'>新标签</button>"""
        return mark_safe(f"<div>{btn1} {btn2}</div>")

 

效果:

 

标签:obj,name,自定义,admin,list,django,display,verbose
From: https://www.cnblogs.com/ubirdy/p/18127381

相关文章

  • Obsidian自定义代码块样式成Typora
    先来效果图修改前效果:修改后效果:编辑模式:预览模式:两种模式的表现间距略有不同,但不影响.添加自定义css样式.markdown-source-view.mod-cm6.cm-content>.HyperMD-codeblock{border-width:01px01px;border-style:solid;border-color:#E7EAE......
  • 【QT入门】Qt自定义控件与样式设计之QPushButton常用qss
    往期回顾【QT入门】Qt自定义控件与样式设计之qss介绍(Qtstylesheet)-CSDN博客【QT入门】Qt自定义控件与样式设计之qss选择器-CSDN博客【QT入门】Qt自定义控件与样式设计之QLineEdit的qss使用-CSDN博客 【QT入门】Qt自定义控件与样式设计之QPushButton常用qss这里我......
  • 【QT入门】 Qt自定义控件与样式设计之QCheckBox qss实现按钮开关
    往期回顾【QT入门】Qt自定义控件与样式设计之QPushButton常用qss-CSDN博客【QT入门】Qt自定义控件与样式设计之QPushButton实现鼠标悬浮按钮弹出对话框-CSDN博客【QT入门】Qt自定义控件与样式设计之QComboBox样式表介绍-CSDN博客 【QT入门】Qt自定义控件与样式设计之......
  • 自定义Python实用函数-返回指定目录及其子目录和指定文件扩展名的文件清单列表
    importosdefget_files(file_path,image_types_set=()):"""返回指定目录及其子目录下、指定文件扩展名的文件清单列表。若image_types_set参数为空,则返回图片文件清单列表。若image_types_set参数为['.*'],则返回所有文件清单列表。"""filenames......
  • 发挥自定义表单开源优势,助力实现流程化办公!
    在数字化发展进程中,利用低代码技术平台、自定义表单开源的优势特点,可以让企业实现流程化办公,从而实现提质增效的办公目的。作为一种新兴的应用开发模式,低代码技术平台获得了很多新老客户朋友的青睐和喜爱,正以它自身的优势和特点为企业的发展强劲赋能。想要了解自定义表单开源优势......
  • 嵌入式开发之瑞芯微RK356x-Buildroot 添加自定义应用程序1
    上一篇我们说到具体如何去配置Buildroot,编译,验证本章我们需要添加自己的应用程序,我们就以helloworld为例子吧1.首先我们进入buildroot目录,并打开package/Config.in拉到最下面添加如下内容menu"NexyhoApp" source"package/Nexyho/Config.in"endmenu2.创建Nexyho文......
  • ROS中自定义全局算法规划器(c++)
     ros中编写一个全局路径规划器并集成为ros插件,加载到turtlebot3机器人平台上仿真验证参考资料:ROS中自定义全局规划器(上)_算法部署_哔哩哔哩_bilibili官网教程:navigation/Tutorials/WritingAGlobalPathPlannerAsPlugininROS-ROSWiki1.建立工作空间mkdir-pjps_......
  • 采用自定义注解 和 AOP 完成日志记录
    1、声明一个自定义注解@Retention注解包含一个RetentionPolicy类型的属性value,用于指定注解的保留策略,常用的保留策略包括:RetentionPolicy.SOURCE:表示注解仅在源代码中保留,编译器编译时会将其忽略,不会保存在编译后的字节码中。RetentionPolicy.CLASS:表示注解在编译后的......
  • java switch 自定义表格的渲染和编辑示例
    目录正常使用表格自定义表格样式正常使用表格很简单,使用一次就知道了,不过多介绍。//创建JTable实例,使用默认的模型JTabletable=newJTable();//设置表格数据Object[][]data={ {1,"Apple",10.0}, {2,"Banana",5.0}, {3,"Orange",8.0}};Object[]col......
  • Seurat Dimplot, Vlnplot画图时报错,Error in setup_panel_guides(..., self = self) :
    SeuratDimplot,Vlnplot画图时报错,Errorinsetup_panel_guides(...,self=self):unusedargument(list(~features.plot,~id))pdf(paste0("EBV_GaC","_Marker_genes_Vln.png"),width=30,height=10)>DotPlot(object=subset_cells,featur......