Ionic / Angular - $scope and This syntax

General Tech Learning Aids/Tools 3 years ago

9.04K 1 0 0 0

Posted on 16 Aug 2022, this text provides information on Learning Aids/Tools related to General Tech. Please note that while accuracy is prioritized, the data presented might not be entirely correct or up-to-date. This information is offered for general knowledge and informational purposes only, and should not be considered as a substitute for professional advice.

Answers (1)

Post Answer
profilepic.png
manpreet Tuteehub forum best answer Best Answer 3 years ago

 

Learning Angular (along with Ionic).

I try and avoid using $scope and stick with controller as syntax ('this' as much as possible, along with Controller as in the HTML). A few days back, I added a service that i found online to aid in better managing my Modal dialogs. That code is attached.

angular.module('myApp').service('RefFilterModal', RefFilterModal);

function RefFilterModal($rootScope, $ionicModal) {
let templateUrl = 'client/templates/modals/refFilterModal.html';

this.showModal = showModal;
this.hideModal = hideModal;

////////////

function showModal () {
this._scope = $rootScope.$new();

$ionicModal.fromTemplateUrl(templateUrl, {
  scope: this._scope,
   animation: 'slide-in-up',
   focusFirstInput: false,
   backdropClickToClose: true
}).then((modal) => {
  this._modal = modal;
  modal.show();
});
}

 function hideModal () {
this._scope.$destroy();
this._modal.remove();
 }
 }

My dilemma is that with this service (that brings up the modal) $scope and 'this' aren't working the same as it does elsewhere. For example, a submit function - while the submit function does get called from the ng-click, the values of year and manufacturer are undefined. If I change the "this.submit" to "$scope.submit" they are defined.

Can someone please educate me as to why that is - I would expect to use THIS all around. Also, what can I do to the service to achieve my aim of sticking with controller as principle? Thanks.

this.submit = function() {

    RefFilters.setYearFilter(this.year);
    RefFilters.setMakerFilter(this.manufacturer);

    RefFilterModal.hideModal();
}

(the html has submit as "refFilter.submit", "refFilter.year", and "refFilter.manufacturer").

0 views
0 shares

No matter what stage you're at in your education or career, TuteeHUB will help you reach the next level that you're aiming for. Simply,Choose a subject/topic and get started in self-paced practice sessions to improve your knowledge and scores.

Similar Forum