Хобрук: Ваш путь к мастерству в программировании

Доступ к элементам управления внутри элементов управления в Xamarin Forms

Я пишу приложение, используя формы Xamarin, и у меня возникла проблема, из-за которой я не могу получить доступ к одному из своих элементов управления, поэтому я надеюсь, что кто-нибудь объяснит мне, как решить мою проблему.

Допустим, у меня есть 2 элемента управления - 1 ListView и 1 Picker.

<Picker x:Name="picker">
...
</Picker>

<ListView x:Name="listView">
...
</ListView>

Если я хочу получить доступ к любому из этих элементов управления из моего кода программной части, я могу просто использовать имена «выборщик» и «listView», и я нахожу их прекрасными.

Однако, если Picker находится внутри ListView:

<ListView x:Name="listView">
    <Picker x:Name="picker">
    ...
    </Picker>
</ListView>

В этом сценарии я вижу элемент управления "listView", но не вижу элемент управления "выборщик".

Что я могу сделать, чтобы получить доступ к элементу управления Picker, когда он находится внутри элемента управления ListView?


  • Чего именно вы пытаетесь достичь? Размещенный вами XAML даже не скомпилируется. 27.04.2018
  • Когда вы размещаете элементы управления внутри шаблона ListView, элемент управления будет повторяться для каждого элемента в ListView. Не существует единого экземпляра элемента управления, на который можно ссылаться по имени. 27.04.2018
  • @Jason Я понимаю, что элемент будет повторяться и что не будет единого экземпляра элемента управления, но у ListView есть индекс, поэтому вы можете различать средства выбора. Если вы настроите это так, чтобы в ListView было 10 средств выбора, каждое из которых имеет набор параметров для выбора, вы бы знали, какое средство выбора было выбрано по индексу ListView. Я просто пытаюсь сделать то же самое, но в обратном порядке. По сути, я хочу иметь возможность выбирать средство выбора для управления, зная его индекс в ListView. 27.04.2018
  • Это просто так не работает. Если в вашем списке 1000 элементов, он не будет создавать 1000 сборщиков. Его будет достаточно для отображения на экране в любой момент времени. Это может помочь, если вы объясните, чего вы пытаетесь достичь, напрямую обращаясь к средствам выбора. 27.04.2018

Ответы:


1

Мне удалось решить эту проблему, отправив ссылку на «сборщик» в качестве параметра команды.

Затем я могу получить доступ к соответствующему средству выбора на основе индекса ListView.

27.04.2018
Новые материалы

Создание кнопочного меню с использованием HTML, CSS и JavaScript
Вы будете создавать кнопочное меню, которое имеет состояние наведения, а также позволяет вам выбирать кнопку при нажатии на нее. Финальный проект можно увидеть в этом Codepen . Шаг 1..

Внедрите OAuth в свои веб-приложения для повышения безопасности
OAuth — это широко распространенный стандарт авторизации, который позволяет приложениям получать доступ к ресурсам от имени пользователя, не раскрывая его пароль. Это позволяет пользователям..

Классы в JavaScript
class является образцом java Script Object. Конструкция «class» позволяет определять классы на основе прототипов с чистым, красивым синтаксисом. // define class Human class Human {..

Как свинг-трейдеры могут использовать ИИ для больших выигрышей
По мере того как все больше и больше профессиональных трейдеров и активных розничных трейдеров узнают о возможностях, которые предоставляет искусственный интеллект и машинное обучение для улучшения..

Как построить любой стол
Я разработчик программного обеспечения. Я люблю делать вещи и всегда любил. Для меня программирование всегда было способом создавать вещи, используя только компьютер и мое воображение...

Обзор: Машинное обучение: классификация
Только что закончил третий курс курса 4 часть специализации по машинному обучению . Как и второй курс, он был посвящен низкоуровневой работе алгоритмов машинного обучения. Что касается..

Разработка расширений Qlik Sense с qExt
Использование современных инструментов веб-разработки для разработки крутых расширений Вы когда-нибудь хотели кнопку для установки переменной в приложении Qlik Sense? Когда-нибудь просили..