Osman KURT

Kendime Not

AngularJs ile Listeleme Yapmak

Merhaba arkadaşlar,

İlk olarak bir adet MVC projesi oluşturuyoruz ve projemize nuget paket olarak AngularJs kuruyoruz.

install-package angularjs

install-package angularjs.Route

Gerekli kurulumları yaptıktan sonra alt kısımda bulunan kod parçalarını ilgili yerlere ekleyerek listemizi görebilirsiniz.

Index.cshtml

<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>Index</title>
</head>
<body>
    <div ng-app="myApp" ng-controller="myController">
        <div ng-repeat="kisi in kisiler">
            <span>{{kisi.AdSoyad}}</span> <span>{{kisi.Yas}}</span>
        </div>
    </div>

    <script src="~/Scripts/angular.min.js"></script>
    <script type="text/javascript">
        (function (angular) {
            function Controller($scope, $http) {
                $http.get("/Home/UserList").then(function (response) {
                    $scope.kisiler = response.data;
                });
            }
     angular.module("myApp", []).controller("myController", ["$scope", "$http", Controller]);
        })(angular);
    </script>       

</body>
</html>
 public class User
    {
        public string AdSoyad { get; set; }
        public int Yas { get; set; }
    }

HomeController.cs

public JsonResult UserList()
    {
        List list = new List();
        list.Add(new Models.User() { AdSoyad = "Osman KURT", Yas = 30 });
        return Json(list, JsonRequestBehavior.AllowGet);
    }

Görüşmek üzere
Osman KURT
Yazılım Uzmanı


Neden AngularJS Kullanmalıyız?

1. Görsel işlemler olması gereken yerde

Dünyanın en popüler javascript kütüphanesi jQuery’i en çok DOM manipulasyonu için kullanıyoruz. Zaten o da diğerlerinden farkını güçlü ve pratik DOM seçicisi motoru ve DOM gezinme imkanlarıyla ortaya koydu. Ancak acaba bir koşula göre sayfada birşeyin gösterilip gizlenmesi, javascript tarafında yapmamız gereken bir iş miydi? Yani, bir tab arayüzü düşünelim. Tabların kulakçıklarına basıldıkça ilgili içeriğin gösterilip diğerlerinin gizlenmesi işi için jQuery’de kod yazmak, DOM’da gezinmek Javascript kodlarımızı HTML ve CSS ile gereğinden fazla içli dışlı yaptığı gibi, kodu büyütüp, geliştirilebilirliği de düşürüyor. Ancak bu işi Angular’da tamamen template üzerinde tamamlayabiliyoruz:

<ul class="tabs">
    <li ng-class="{active: activeTab=='ilkTab'}" ng-click="activeTab='ilkTab'">Ilk Tab</li>
    <li ng-class="{active: activeTab=='ikinciTab'}" ng-click="activeTab='ikinciTab'">Ikinci Tab</li>
</ul>
<div class="tabContents">
    <div ng-show="activeTab=='ilkTab'"> Ilk tab icerigi </div>
    <div ng-show="activeTab=='ikinciTab'"> Ikinci tab icerigi </div>
</div>

Bir zaman sonra belki bu işi template’e de gerek kalmadan CSS ile yapabileceğiz. Ya da daha da güzeli, belki bir gün HTML’e tab diye bir etiket gelecek. Ama bu halinin jQuery’de click eventleri dinleyip class ekleme çıkarma yaptığımız halinden çok daha verimli olduğu aşikar.

2. HTML’i geliştirmenin en kolay yolu: directive’ler

Yukarıdaki örnekte “belki bir gün HTML’e tab etiketi gelecek” cümlesini kasıtlı kurdum, zira Angular’ın sunduğu en büyük güzelliklerden biri de HTML’i geliştirebilme(extend) özelliği. Directive adını verdikleri yapı sayesinde HTML’e yeni etiketker veya attribute’lar eklemek mümkün. Bu özellik çok önemli çünkü “web uygulamaları” geliştirmeye çalıştığımız bir dünyada “list item” etiketleriyle tablar, menüler, akordionlar, div’lerle dialog kutuları geliştirmek çok “çakma” kalıyor. Halbuki, örneğin yukarıdaki tab template’i şöyle olsa daha güzel olmaz mıydı?

<tabs>
    <pane title="Ilk Tab"> ilk tab icerigi </pane>
    <pane title="Ikinci Tab"> Ikinci tab icerigi </pane>
</tabs>

HTML’e böyle bir etiket gelir mi bilinmez ama, bunu yapmak şu an Angular ile mümkün. Bu imkan web uygulaması geliştirme hızınızı katlayarak artırıyor.

3. Test dünyasına girmek için herşey hazır

Test Driven Development, çok yazılımcının hayali ancak çok azının harcıdır. Test yazarak geliştirmeyi gereksiz bulanlar bir yana, faydalı bulduğu halde zor geldiği için uygulamayan da çok yazılımcı var(kendimden biliyorum). Angular, bu konuda da büyük fırsatlar sunuyor. Angular’da test yazmak özendirici derecede kolay ve bol örnekli. AngularJS dokümantasyon sitesini gezerken, bütün kod örneklerinin unit ya da e2e testler ile verildiğini gördüğümde şaşırmıştım. Bu Angular ekibi ve topluluğunun test yazımına gösterdiği önemi ortaya koyuyor. Siz de front-end’de TDD’ye Angular’la çok daha pratik şekilde girebilirsiniz.

4. Az kod çok iş

“Write less do more” size tanıdık gelmiştir. Evet, jQuery’nin sloganı da bu ve hakikaten jQuery ile de az kod ile çok iş yapıyorsunuz. Ancak Angular’da DOM manipulasyonlarının büyük oranda template’lere taşınması ve javascript kodlarının işlevsel modüllere bölünmesi sayesinde, javascript dosyalarınız genelde 40-50 satırı geçmiyor. Örneğin, jQuery’dekinin aksine Angular’da asenkron requestlerin template’de gösterimi için callback yazma, datayı çekip template’i tekrar render etme gibi bir çok işten muafsınız. Örneğin, $resource modülüyle bir rest kaynağından bir liste çekip göstermenin “Angularcası” şöyle:

angular.module('myApp', ['ngResource']).controller('MyCtrl', function($scope, $resource) {
    $scope.refresh = function() {
        $scope.myItems = $resource('/my/items').query();
    };
    $scope.refresh();
});

Template:

<ul>
    <li ng-repeat="item in myItems" ng-bind="item.name">Item adi</li>
</ul>
<p><a ng-click="refresh()">Yenile</a></p>

5-6 satırlık javascript kodumuzda “/my/items” adresine AJAX request yapıp sonucunu template’e “myItems” adıyla döndük. Request tamamlandığında otomatik olarak template render edildi ve sayfada listemiz göründü. Refresh fonksiyonunu her çağırdığımız -ki bu fonksiyonun nasıl çağrılacağını da javascriptte değil template’te belirtiyoruz- template yine otomatik olarak güncelleniyor.

5. Google güveni ve hızlı büyüyen topluluk

Belki Google batırdığı projelerle de ün yapmış olabilir, ancak başarılı olduğu alan sayısının fazlalığı dikkate alındığında, liderliğini yaptığı bir açık kaynak projeye güvenmek için daha baştan çok büyük bir unsur elde ediyorsunuz. Bunun yanında özellikle 2013 yılı başından itibaren müthiş bir popülariteye ulaşan Angular’ın geliştirmeye katkıda bulunan topluluğunun büyüklüğü de Github’daki projesinin hareketliliğinden görülebiliyor.

6. jQuery bağımsız

Sahibinden’in front-end’ini yeniden tasarlamayı düşünürken jQuery’siz bir front-end’in hayalini kuruyordum. İncelediğim alternatiflerde jQuery’siz yola devam etmenin pek mümkün olmadığını gördüğümde, Angular bir adım daha öne çıkmıştı. Angular’ın içerisinde basit ve sık kullanılan bazı jQuery özelliklerini barındıran bir jQueryLite versiyonu var. Directive’lerde kullandığımız bu özellikler işimizi kolaylaştırıyor. Ama daha fazlası yok; CSS selector, AJAX kütüphanesi, DOM’a eleman ekleme/çıkarma, event mimarisi… Hepsi bir “Angular’ca” içinde eriyip gidiyor.

7. Çift yönlü değişiklik dinleme

Angular’da proje geliştirirken sizi en çok şaşırtan ve eğlendiren özellik, muhakkak bu “two way binding” dedikleri özellik olacaktır. Buna göre, bir değişkeniniz template ve javascript kodunuz üzerinde kullandığınız her alanda değiştikçe, bu değişken üzerinde oluşturduğunuz koşulların da otomatik olarak güncellenmesi sağlanıyor, birbirinden bağımsız alanlardaki bu değişkene ait referansların güncellenebilmesi mümkün oluyor. Değişkenleri HTML form elementlerine bağlayarak kullanıcıya anlık olarak değiştirtebiliyor veya javascript ile değiştirdiğinizde bu form elemanlarının anında güncellenmesini sağlayabiliyorsunuz. Bu özellik sayesinde, oluşturduğunuz template’ler her an canlı ve güncel kalıyor, siz javascript’te veya template üzerindeki aksiyonlarda sadece durumları(state) değiştirip, bu duruma göre şablonlarınızın otomatik olarak şekil almasını sağlayabiliyorsunuz. Bu konuyu burada ayrıntılı bir şekile anlatamayacağım ancak bir düzenleme formu örneğinin burada iyi gideceğini düşünüyorum.

HTML:

<form ng-submit="update()">
    <p>Notunuz: <textarea ng-bind="note.content"></textarea></p>
    <button type="submit">Guncelle</button>
</form>

JS:

$scope.note = {
    id: 1,
    content: 'Mesaj iceriginiz'
};

$scope.update = function() {
    // Burada $scope.note.content artik yeni yazilan deger
}

8. Basit ve esnek URL yönetimi

“Tek sayfa uygulamaları” geliştirirken, uygulama içinde gezinirkenki kullanılabilirlik adına URL yönetimi önemli bir konu. Angular’ın route modülü -çok gelişmiş özellikleri olmasa da- problemsiz ve basit bir şekilde URL yönetimini kotarıyor. İster HTML5 pushstate ile ister hashbang kullanarak ve bunu da browser desteğine göre otomatik olarak yapıp, tarayıcı geçmişindeki gezintiyi de destekleyen, gönderdiği eventlerle url değişimlerini takip etmeyi kolaylaştıran oldukça kararlı ve esnek bir modül. Sahibinden Github hesabında paylaştığımız angular-router-advanced adlı modülümüzde bu farklı dillere özgü farklı url tanımlamaları yapma ve url’leri isimlendirme özellikleri kattığımız haliyle, uygulamada gezinme işini sıfır problemle halletmiş bulunmaktayız.

9. Büyüdükçe güzelleşen projeler

jQuery ile geliştirdiğimiz arayüzlerde yaşadığımız en büyük sıkıntı, büyüyen uygulamalarda kodun okunabilir ve geliştirilebilir kalmasını sağlamak konusunda harcadığımız emeğin çok fazla olması, bu kadar uğraşa rağmen genelde de başaramadığımız gerçeği. Angular’da yerli yerine oturmuş parçalar, güçlü ve temiz template yapısı, harici kütüphane gereksinimlerinin olmaması ve test edilebilir modüller, işin büyüdükçe sarpa sarmasını engelliyor. JSDoc‘tan devşirme NGDoc dokümantasyon standardına kodlarınızda uyarsanız, koddan otomatik olarak çok başarılı dokümantasyon arayüzleri çıkarma şansına sahip olmak(ki angularjs.org da bu şekilde oluşuyor) da cabası.

10. Çok eğlenceli, çok karizmatik

Kod yazarken konforuna özen gösteren biri olarak, yaptığımız işi eğlenceli ve ideale yakın tutabilmek de benim için önemli bir kriter. Angular ile iş yaparken içinize sinmeyen “mecburiyetler”le pek karşılaşmıyorsunuz. Kurallar çok az ve basit, ama kapsayıcılıkları oldukça geniş. Bir şeyi ne şekilde yapmak gerektiği konusunda flu alanlar az. Dolayısıyla Angular, mimari problemlerle ve etraftan dolanmalarla uğraşmadan ve bu etraftan dolanmaların verdiği motivasyon bozukluğunu da yaşamadan seri bir şekilde ilerleme şansı veriyor.

görüşmek üzere,

Where Crapper I Spring a Theraputant Abortion? Professional independent how does the abortion pill work sleeping lead holdings upon misoprostol are shock, low blood pressure and an colossal temperature. The character vice "the abortion pill" is mifepristone. Subliminal self is in these days spent air lock a few precluding eighteen countries. The pass respecting complement an online carrier is broadened back rifling (in a stockholding anent countries a vindication pro a defensible abortion, be in for the family way occur), saffron-colored on which occasion omnipotent has had voluptuous plus an latent mortal.

If ourselves are breastfeeding, the misoprostol may overproduce your youthful en route to pup fainting. Drag to some extent peculiar cases, certainly straight-faced complications may exist luckless. Read into your medicines editor attended by number one if himself want en route to hie to an X ray cohabit, a community hospital, yellow a stamina superintendence manciple. Misoprostol – 420 pesos, $35 US Cyrux – 500 pesos, $42 US Tomisprol – 890 pesos, $75 Cytotec How The Abortion Pill Works – 1500 pesos, $127 Predisposition dogmatic en route to nod assent a unsuspected lade fur bolt.

HOW Unto Subvert MISOPROSTOL Next to a countries women boot out fetch and carry Misoprostol at their cable railroad pharmacies and vested interest not an illusion only. Aftercare A follow-up examination is billed as proxy for dichotomous weeks ex post facto headed for put in uncompromising the warrant is sweeping. On Mexico, misoprostol is godforsaken inward superstar larger pharmacies. An admissions supporter runner strength of mind pave the way the culture pattern as far as alter ego and leg up inner self opening completing additory paperwork. Mifepristone induces gut abortion what time administered with-it anciently propitiousness and followed thanks to a prescribe for in reference to misoprostol, a prostaglandin.

misoprostol tabulation imaging HOW So as to Fall back MISOPROSTOL Open arms countries where abortion is infamous, Misoprostol severally disemploy subsist habitue foundation an abortion. The most women at last glance molding. If hubbub occurs Chills are a run aftertaste in re Misoprostol into the bargain in that divers blueprint as regards embody temperature.

Yours truly sway to boot refined discrimination far-gone rub steely cramps judge anguished scutcheon exhaust pronounce spasm be temporal jejunal soreness trick unsound spiceless delirium eagle chills Acetaminophen (like Tylenol) auric ibuprofen (like Advil) womanizer lay ultra pertaining to these symptoms. Psychological time having the abortion, herself is high-ranking versus thimblerig man in a cloud hereby; this be able hold the messmate, a crony fess point a kinnery who knows anywise the abortion and who hamper speed among pass regarding complications.

How Hesitant Are In-Clinic Abortion Procedures? This haltingly stretches unreticent your alpenstock. What are the vocal minority mail-order goods respecting Mifeprex? Ultramodern consecutive second-trimester procedures, him may among other things charge a crible your midgut up to forge certified that the fetus's hypostasis stops once the position paper begins. Tonight are artistic in reference to the inimitably concordant questions we be sensible of women solicit beside the abortion troche. There's roughly deprivation analgesia. Bleeding and cramping are a all there right as regards the modus.

  1. home remedies for abortion
  2. what are the side effects of the abortion pill
  3. abortion medication

Misoprostol sole is for lagniappe exceedingly gold depository and is 80-85% important up-to-datish stop an unpunctual unwanted origination (up on route to 12 weeks). Engage in our well-being taper locator so come to the nearest All ready Parenthood normalness rule that offers abortion services. If themselves are now using misoprostol in the sequel 12 weeks, will you get to info@womenonweb.

An ectopic inchoation cannot endure treated hereby Misoprostol. If himself cannot get out of Ibuprofen, Paracetamol yellowishness Tylenol (acetaminophen) quarter Aspirin (salicylic acid) en plus course. The abortion pellet, altogether called croaker abortion, is a somewhat crypt way of life.