gpt4 book ai didi

jquery - 将其他数据获取到 django 表单下拉选择中

转载 作者:可可西里 更新时间:2023-11-01 07:08:21 24 4
gpt4 key购买 nike

我有一个 Action 模型,它有一个外键,它指定了一个 Action 重复发生的频率:

class Reoccurance(models.Model):
label = models.CharField("Label", max_length=50, unique = True)
days = models.IntegerField("Days")

def __unicode__(self):
return self.label

class Meta:
ordering = ['days']

class Action(models.Model):
name = models.CharField("Action Name", max_length=200, unique = True)
complete = models.BooleanField(default=False, verbose_name="Complete?")
reoccurance = models.ForeignKey(Reoccurance, blank=True, null=True, verbose_name="Reoccurance")

我正在制作一个 modelForm of Action,它会生成用于重现的 HTML 代码(基于重现表存在的数据库值):

<select id="id_reoccurance" class="select" name="reoccurance">
<option value="" selected="selected">---------</option>
<option value="12">2 Days</option>
<option value="1">3 Days</option>
<option value="2">5 Days</option>
<option value="10">6 Days</option>
<option value="9">1 Week</option>
<option value="3">10 Days</option>
<option value="4">2 Weeks</option>
<option value="11">3 Weeks</option>
<option value="5">1 Month</option>
<option value="13">6 Weeks</option>
<option value="6">1 Quarter</option>
<option value="7">6 Months</option>
<option value="8">1 Year</option>
</select>

如您所见,虽然选择是按日升序排列的,但值是乱序的,因为它们输入数据库的顺序是乱序的。

我想创建一些 jquery 来动态计算操作再次发生的日期。它将采用今天的日期并添加与用户选择的选项相对应的天数。但是根据我在表格中获得的数据,我无法将选择转换为设定的天数。即使选项项的值是有序的,它仍然不表示说“1 年”等于 365 天。

尽管此数据位于 Reoccurance 表中。对于标签 =“1 年”,天数 = 365。对于 Reoccurance 表中的所有项目也是如此。

有没有办法重写我的 modelForm,使每个下拉项的选项值可能等于该选择的天数?因为那时,我可以访问天数:

$("#id_reoccurance").change(function() {
alert( $(this).val() );
});

这是否会对我将正确的重现选择与重现表的正确行相关联的能力产生不利影响?有没有其他方法可以在我的表单模板上访问 this days/label tie in jquery?

更新

感谢Joseph建议查看this post ,我能够在我的选项元素中包含一个标题:

from django.utils.html import conditional_escape, escape
from django.utils.encoding import force_unicode

class SelectWithTitles(forms.Select):
def __init__(self, *args, **kwargs):
super(SelectWithTitles, self).__init__(*args, **kwargs)
# Ensure the titles dict exists
self.titles = {}

def render_option(self, selected_choices, option_value, option_label):
title_html = (option_label in self.titles) and \
u' title="%s" ' % escape(force_unicode(self.titles[option_label])) or ''
option_value = force_unicode(option_value)
selected_html = (option_value in selected_choices) and u' selected="selected"' or ''
return u'<option value="%s"%s%s>%s</option>' % (
escape(option_value), title_html, selected_html,
conditional_escape(force_unicode(option_label)))

class ChoiceFieldWithTitles(forms.ChoiceField):
widget = SelectWithTitles

def __init__(self, choices=(), *args, **kwargs):
choice_pairs = [(c[0], c[1]) for c in choices]
super(ChoiceFieldWithTitles, self).__init__(choices=choice_pairs, *args, **kwargs)
self.widget.titles = dict([(c[1], c[2]) for c in choices])

class ActionForm(forms.ModelForm):
reoccurance = ChoiceFieldWithTitles()

def __init__(self, *args, **kwargs):
super(ActionForm, self).__init__(*args, **kwargs)

choices = []
for pt in Reoccurance.objects.all():
choices.append((pt.id, pt.label, pt.days))
self.fields['reoccurance'] = ChoiceFieldWithTitles(choices = choices)

太棒了。所以现在我在我的模板中得到以下内容:

<select id="id_reoccurance" class="selectwithtitles" name="reoccurance">
<option value="12" title="2" >2 Days</option>
<option value="1" title="3" >3 Days</option>
<option value="2" title="5" >5 Days</option>
<option value="10" title="6" >6 Days</option>
<option value="9" title="7" >1 Week</option>
<option value="3" title="10" >10 Days</option>
<option value="4" title="14" >2 Weeks</option>
<option value="11" title="21" >3 Weeks</option>
<option value="5" title="30" >1 Month</option>
<option value="13" title="42" >6 Weeks</option>
<option value="6" title="90" >1 Quarter</option>
<option value="7" title="180" >6 Months</option>
<option value="8" title="365" >1 Year</option>
</select>

好吧,看起来我们快到了,但我被绊倒了。在 jquery 中,我正在尝试以下操作来获取所选选项的标题:

$(function() {
$("#id_reoccurance").change(function() {
alert($(this).attr('title'));
});
});

问题是它返回时未定义!

更新 知道了

$(function() {
$("#id_reoccurance").change(function() {
alert($(this).find("option:selected").attr("title"));
});
});

最佳答案

基于 this question/answer (这是粗略的,未经测试,希望是一个开始):

class myClassForm(forms.Form):
class Meta:
model = myClass
fields=["name"]

reoccurrance = forms.ChoiceField(label="Reoccurance", choices=(),
widget=forms.Select(attrs={'class':'selector'}))


def __init__(self, *args, **kwargs):
super(myClassForm, self).__init__(*args, **kwargs)
choices = []
for pt in Reoccurance.objects.all():
choices.append((pt.id, unicode(pt.days)))
self.fields['reoccurrance'].choices = choices

关于jquery - 将其他数据获取到 django 表单下拉选择中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12306841/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com