Выбор элемента управления возвращает [объект объекта] в Angular 7

Как объяснили другие, встроенный dict не делает то, что вы хотите. Но в Python2 (и, вероятно, 3 тоже) вы можете легко создать класс ValueDict, который копирует с помощью =, чтобы вы могли быть уверены, что оригинал не изменится.

class ValueDict(dict):

    def __ilshift__(self, args):
        result = ValueDict(self)
        if isinstance(args, dict):
            dict.update(result, args)
        else:
            dict.__setitem__(result, *args)
        return result # Pythonic LVALUE modification

    def __irshift__(self, args):
        result = ValueDict(self)
        dict.__delitem__(result, args)
        return result # Pythonic LVALUE modification

    def __setitem__(self, k, v):
        raise AttributeError, \
            "Use \"value_dict<<='%s', ...\" instead of \"d[%s] = ...\"" % (k,k)

    def __delitem__(self, k):
        raise AttributeError, \
            "Use \"value_dict>>='%s'\" instead of \"del d[%s]" % (k,k)

    def update(self, d2):
        raise AttributeError, \
            "Use \"value_dict<<=dict2\" instead of \"value_dict.update(dict2)\""


# test
d = ValueDict()

d <<='apples', 5
d <<='pears', 8
print "d =", d

e = d
e <<='bananas', 1
print "e =", e
print "d =", d

d >>='pears'
print "d =", d
d <<={'blueberries': 2, 'watermelons': 315}
print "d =", d
print "e =", e
print "e['bananas'] =", e['bananas']


# result
d = {'apples': 5, 'pears': 8}
e = {'apples': 5, 'pears': 8, 'bananas': 1}
d = {'apples': 5, 'pears': 8}
d = {'apples': 5}
d = {'watermelons': 315, 'blueberries': 2, 'apples': 5}
e = {'apples': 5, 'pears': 8, 'bananas': 1}
e['bananas'] = 1

# e[0]=3
# would give:
# AttributeError: Use "value_dict<<='0', ..." instead of "d[0] = ..."

Пожалуйста, обратитесь к шаблон изменения lvalue, обсуждаемый здесь: Python 2.7 - чистый синтаксис для модификации lvalue . Главное наблюдение заключается в том, что str и int ведут себя как значения в Python (даже если они фактически являются неизменяемыми объектами под капотом). В то время как вы это замечаете, также обратите внимание, что ничего особенного в str или int нет. dict можно использовать почти одинаково, и я могу думать о многих случаях, когда ValueDict имеет смысл.

0
задан Jadda 16 January 2019 в 19:07
поделиться

1 ответ

Две вещи.

Во-первых: в ваших настройках есть

<option *ngFor="let jobType of jobTypeObservable" [value]="jobType"> 
      {{jobType.name}}
</option>

Итак, значение является объектом типа jobType, который вы можете использовать, например. если у вашего jobType есть свойство с именем "id" [value] = jobType.id

<option *ngFor="let jobType of jobTypeObservable" [value]="jobType.id"> 
      {{jobType.name}}
</option>

Итак, вы получили в своей функции "id", а не весь объект

Секунда: в реактивной форме обычно вы подписываетесь на изменения значений - не используется (изменено) -. затем, после создания формы

jobsForm.get('jobTypeControl').valueChanges.subscribe(value=>
   { //here you has the value of jobTypeControl
      console.log(value)
   }
)
0
ответ дан Eliseo 16 January 2019 в 19:07
поделиться
Другие вопросы по тегам:

Похожие вопросы: