Добавить переключатель к значку в AngularJS

Есть значок (в данном случае каретка), который запускает вызов функции при нажатии. Он должен запускать функцию, только если values.numerOfValues > 0

<td>   
 <span >{{values.numerOfValues}} 
        <i class = "fas fa-caret-down" ng-click = "values.numerOfValues > 0 && $ctrl.myFunction(values.ids)">
        </i>
    </span>
</td>

Вышеупомянутая часть работает хорошо.

Проблема возникает, когда я хочу добавить переключаемое меню. Я не хочу, чтобы функция вызывалась при щелчке по значку, вместо этого я хочу, чтобы при щелчке по ней открывался переключатель с опцией и только при щелчке опции для выполнения вызова.

Мне удалось сделать эту функциональность вот такой:

<div class = "yp-split-button" uib-dropdown>
    <button type = "button" class = "yp-action-btn" uib-dropdown-toggle>
    </button>
    <ul class = "dropdown-menu" uib-dropdown-menu role = "menu">
        <li role = "menuitem" ng-click = "$ctrl.myFunction(values.ids)"><a>Disable All</a></li>
    </ul>
</div>

Переключатель открывается при нажатии кнопки внутри красного круга. Моя цель - перенести эту функцию на кнопку внутри зеленого кружка.

Это функциональность, о которой я говорил в начале. Он вызывает функцию напрямую, не открывая переключатель.

Как перенести функциональность кнопки на каретку?

Добавить переключатель к значку в AngularJS

Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
0
0
49
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

С чистым javascript переключать:

document.getElementsByClassName("yp-action-btn")[0].onclick = (function(){
  toggle(dropdown)
})


function toggle(id){ 
 if (id.classList[0] === "hidden"){
    id.classList = "unhidden"
  }
  else {
    id.classList = "hidden"
  }
}
.hidden {display: none}
.unhidden {display: block}
<div>
    <button type = "button" class = "yp-action-btn">Toggle
    </button>
    <ul class = "hidden" id = "dropdown">
        <li>
        <a onclick = "alert()">Disable All</a>
        </li>
    </ul>
</div>
Ответ принят как подходящий

Я решил проблему следующим образом:

<td>
    <div class = "dropdown enable-status" uib-dropdown>
        <span >{{values.numerOfValues}}</span>
        <span ng-disabled = "!values.numerOfValues" uib-dropdown-toggle><i class = "fas fa-caret-down"></i></span>
        <ul class = "dropdown-menu" uib-dropdown-menu role = "menu">
            <li role = "menuitem" tabindex = "0"><a ng-click = "$ctrl.myFunction(values.ids)">Disable all</a></li>
        </ul>
    </div>
</td>

Другие вопросы по теме