我遇到了Django内置的slugify函数的问题。我正在建立一个使用Django框架的网站。该网站必须有一个论坛应用程序。经过一番搜索,我找到了一个。它工作得很好,但是它在主题标题上大量使用了slugify函数来创建指向其页面的“人类可读”链接。问题是,我们是用俄语编写的,因此,当尝试从浏览器复制链接时,它会生成非ASCII URL,这些URL看起来像一堆无法读取的unicode数据(并且在尝试记录它们时也会抛出异常)。
有没有一种方法可以全局覆盖整个项目的Django的django.utils.text.slugify,这样我就不需要只为了更改models.py中的import语句而包含一半的第三方库?
发布于 2018-12-11 10:04:49
保存而不是全局的一种方式是编写你自己的slugify函数,然后你可以通过在你想要slugify /字段的模型的覆盖的方法中调用它来利用它。
例如:
class Post(models.Model):
title = models.CharField(max_length=512)
slug = models.CharField(max_length=1024)
def save(self, *args, **kwargs):
your_slugify_function(self, self.title)
super(Post, self).save(*args, **kwargs)发布于 2018-12-11 11:39:21
我认为您可以通过使用slugify函数覆盖abstract方法来定义一个保存模型类。如下所示:
class AbstractBase(models.Model):
slug = models.SlugField()
class Meta:
abstract = True
def save(self, *args, **kwargs):
self.slug = slugify.Slugify(self.slug)
return super(AbstractBase, self).save(*args, **kwargs)然后从这个abstract类中创建剩余模型的子类,如下所示:
class Post(AbstractBase):
# rest of the post fields这样,slugify将只在一个地方完成,并在所有模型上全局工作。
https://stackoverflow.com/questions/53715907
复制相似问题