Skip to main content

create-eth-app ile dapp ön uç geliştirmenizi başlatın

create-eth-app
ön uç
javascript
ethers.js
the graph
defi
Gelişmiş
Markus Waas
27 Nisan 2020
5 dakikalık okuma

Geçen sefer Solidity'nin büyük resmine baktık veopens in a new tab hâlihazırda create-eth-appopens in a new tab'den bahsettik. Şimdi onu nasıl kullanacağınızı, hangi özelliklerin entegre olduğunu ve nasıl genişleteceğinize dair ek fikirleri öğreneceksiniz. Sablieropens in a new tab'in kurucusu Paul Razvan Berg tarafından başlatılan bu uygulama, ön uç geliştirmenizi başlatacak ve beraberinde aralarından seçim yapabileceğiniz çeşitli isteğe bağlı entegrasyonlar getiriyor.

Kurulum

Kurulum için Yarn 0.25 veya üstü gerekir (npm install thread --global). Şunları çalıştırmak kadar kolaydır:

yarn create eth-app my-eth-app
cd my-eth-app
yarn react-app:start

Perde arkasında create-react-appopens in a new tab kullanır. Uygulamanızı görmek için, http://localhost:3000/ bağlantısını açın. Üretime dağıtmaya hazır olduğunuzda, yarn build ile küçültülmüş bir paket oluşturun. Bunu sunmanın kolay yollarından biri Netlifyopens in a new tab'dır. Bir Github deposu oluşturmanız, Netlify'a eklemeniz ve build komutunu kurmanız yeterli olur! Uygulamanız barındırılacak ve herkes tarafından kullanılabilir olacak. Ve hepsi ücretsiz.

Özellikler

React ve create-react-app

Öncelikle uygulamanın kalbi: React ve create-react-app ile gelen tüm ek özellikler. Sadece bunu kullanmak, Ethereum'u entegre etmek istemiyorsanız harika bir seçenektir. Reactopens in a new tab kendi başına interaktif UI'lar yapmayı gerçekten kolaylaştırır. Vueopens in a new tab kadar yeni başlayanlar için uygun olmayabilir, ancak yine de çoğunlukla kullanılmaktadır, daha fazla özelliğe sahiptir ve en önemlisi aralarından seçim yapabileceğiniz binlerce ek kütüphane vardır. create-react-app, onunla başlamayı gerçekten kolaylaştırır ve şunları içerir:

  • React, JSX, ES6, TypeScript, Flow söz dizimi desteği.
  • Nesne yayma operatörü gibi ES6'nın ötesinde dil ekstraları.
  • Autoprefixer CSS, yani -webkit- veya diğer ön eklere ihtiyacınız yok.
  • Kapsam raporlaması için yerleşik desteğe sahip hızlı etkileşimli birim test çalıştırıcısı.
  • Yaygın hatalar hakkında uyaran canlı bir geliştirme sunucusu.
  • Hash değerleri ve kaynak haritaları içeren, üretim için JS, CSS ve görüntüleri bir araya getirmeye yarayan bir derleme komut dosyası.

Özellikle create-eth-app, yeni kanca efektleriniopens in a new tab kullanır. Güçlü, ancak çok küçük sözde fonksiyonel bileşenler yazmak için bir yöntem. create-eth-app'de nasıl kullanıldığını öğrenmek için aşağıdaki Apollo hakkındaki bölüme bakın.

Yarn Workspaces

Yarn Workspacesopens in a new tab, birden çok pakete sahip olmanızın yanı sıra kök klasörden hepsini aynı anda yarn install kullanarak yönetmenize izin verir. Bu, özellikle her ikisi de create-eth-app'in bir parçası olan akıllı sözleşme adresleri/ABI yönetimi (hangi akıllı sözleşmeleri nereye yerleştirdiğiniz ve bunlarla nasıl iletişim kuracağınızla ilgili bilgiler) veya grafik entegrasyonu gibi daha küçük ek paketler için mantıklıdır.

ethers.js

Hâlâ çoğunlukla Web3opens in a new tab kullanılıyor olsa da, ethers.jsopens in a new tab son bir yıl içinde bir alternatif olarak büyük ivme kazanmış ve create-eth-app içine entegre edilmiştir. Bununla çalışabilir, onu Web3 olarak değiştirebilir veya neredeyse beta sürümünden çıkmış olan ethers.js v5opens in a new tab'e yükseltmeyi düşünebilirsiniz.

The Graph

GraphQLopens in a new tab, Restful APIopens in a new tab'ye kıyasla verileri işlemenin alternatif bir yoludur. Özellikle merkeziyetsiz blok zinciri verileri için Restful Api'lere göre çeşitli avantajları vardır. Eğer bunun ardındaki sebepler konusunda meraklıysanız, GraphQL Merkeziyetsiz Ağı Güçlendirecekopens in a new tab'e bir göz atın.

Genellikle akıllı sözleşmenizden doğrudan veri alırsınız. En son işlemin gerçekleştiği zamanı okumak mı istiyorsunuz? Sadece Ethereum düğümünden merkeziyetsiz uygulamanıza veriyi getiren MyContract.methods.latestTradeTime().call()'u çağırın. Peki ya yüzlerce farklı veri noktasına ihtiyacınız varsa? Bu, düğüme yüzlerce veri alınmasına yol açar ve bu alımların her biri bir RTTopens in a new tab gerektirerek merkeziyetsiz uygulamanızı yavaş ve verimsiz hâle getirir. Bir geçici çözüm, sözleşmenizin içinde aynı anda birden çok veri döndüren bir alıcı çağrı işlevi olabilir. Ancak bu her zaman ideal değildir.

Tarihsel verilerle de ilgileniyor olabilirsiniz. Yalnızca son işlem zamanını değil, kendi yaptığınız tüm işlemlerin zamanlarını da bilmek istiyorsunuz. create-eth-app alt grafik paketini kullanın, belgeleriopens in a new tab okuyun ve kendi sözleşmelerinize uyarlayın. Popüler akıllı sözleşmeler arıyorsanız, zaten bir alt grafik bile olabilir. Alt grafik gezginiopens in a new tab'ne bir göz atın.

Bir alt grafiğiniz olduğunda, ihtiyacınız olan geçmiş veriler de dahil olmak üzere tüm önemli blok zinciri verilerini alan merkeziyetsiz uygulamanıza basit bir sorgu yazmanıza olanak tanır, yalnızca tek bir getirme gerekir.

Apollo

Apollo Boostopens in a new tab entegrasyonu sayesinde grafiği React merkeziyetsiz uygulamanıza kolayca entegre edebilirsiniz. Özellikle React hooks ve Apolloopens in a new tab kullanılırken, verileri almak, bileşeninize tek bir GraphQl sorgusu yazmak kadar basittir:

1const { loading, error, data } = useQuery(myGraphQlQuery)
2
3React.useEffect(() => {
4 if (!loading && !error && data) {
5 console.log({ data })
6 }
7}, [loading, error, data])

Şablonlar

Üstte birkaç farklı şablon arasından seçim yapabilirsiniz. Bir Aave, Compound, UniSwap veya sablier entegrasyonu kullanabilirsiniz. Hepsi, önceden yapılmış alt grafik entegrasyonlarının yanı sıra önemli hizmet akıllı sözleşme adresleri ekler. Şablonu, oluşturma komutuna yarn create eth-app my-eth-app --with-template aave şeklinde eklemeniz yeterlidir.

Aave

Aaveopens in a new tab merkeziyetsiz bir borç verme piyasasıdır. Mevduat sahipleri pasif bir gelir elde etmek için piyasaya likidite sağlarken, borçlular teminat kullanarak borç alabilirler. Aave'nin benzersiz bir özelliği, krediyi tek işlemde iade ettiğiniz sürece herhangi bir teminat olmadan borç para almanıza olanak tanıyan hızlı kredilerdiropens in a new tab. Bu, örneğin arbitraj ticaretinde size ekstra nakit vermek için faydalı olabilir.

Size faiz kazandıran takas edilmiş token'lara aTokens denir.

Aave'yi create-eth-app ile entegre etmek istediğinizde, bir alt grafik entegrasyonuopens in a new tab alacaksınız. Aave, The Graph'i kullanır ve size Ropstenopens in a new tab ve Mainnet'teopens in a new tab safopens in a new tab veya formatlanmışopens in a new tab olarak birkaç kullanıma hazır alt grafik sağlar.

Aave Hızlı Kredi meme'i - "Şey, hızlı kredimi 1 işlemden daha uzun süre tutabilseydim, bu müthiş olurdu"

Compound

Compoundopens in a new tab, Aave'ye benzer. Bu entegrasyon hâlihazırda yeni Compound v2 Alt Grafiğiniopens in a new tab kapsar. Burada faiz kazandıran token'lara şaşırtıcı bir şekilde cTokens denir.

Uniswap

Uniswapopens in a new tab, merkeziyetsiz bir borsadır (DEX). Likidite sağlayıcıları, bir ticaretin her iki tarafı için gerekli token'ları veya ether'ı sağlayarak ücret kazanabilir. Yaygın olarak kullanılır ve bu nedenle çok çeşitli token'lar için en yüksek likiditelerden birine sahiptir. Örneğin, kullanıcıların ETH'lerini DAI ile takas etmelerine olanak tanımak için merkeziyetsiz uygulamanıza kolayca entegre edebilirsiniz.

Ne yazık ki, bu yazının yazıldığı sırada entegrasyon yalnızca Uniswap v1 içindir ve yeni yayınlanan v2opens in a new tab için değildir.

Sablier

Sablieropens in a new tab, kullanıcıların para ödemesi akışlarını yürütmesine olanak tanır. Tek bir ödeme günü yerine, ilk kurulumdan sonra başka bir yönetim olmaksızın paranızı sürekli olarak alırsınız. Bu entegrasyon kendi alt grafiğiniopens in a new tab içerir.

Sırada ne var?

create-eth-app hakkında sorularınız varsa, create-eth-app'in yazarlarıyla iletişim kurabileceğiniz Sablier topluluk sunucusunaopens in a new tab gidebilirsiniz. Bir sonraki adım olarak Material UIopens in a new tab gibi bir UI çerçevesini entegre edebilir, ihtiyacınız olan veriler için GraphQL sorguları yazabilir ve dağıtımı kurabilirsiniz.

Page last update: 3 Şubat 2025

Bu rehber yararlı oldu mu?