<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Yunus</title>
    <description>The latest articles on DEV Community by Yunus (@yunuse).</description>
    <link>https://dev.to/yunuse</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F831567%2F4778d2f6-46ee-48f7-b10a-187a092e58f2.png</url>
      <title>DEV Community: Yunus</title>
      <link>https://dev.to/yunuse</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/yunuse"/>
    <language>en</language>
    <item>
      <title>Difference Between onBlur vs onTouched</title>
      <dc:creator>Yunus</dc:creator>
      <pubDate>Fri, 24 Nov 2023 11:29:41 +0000</pubDate>
      <link>https://dev.to/yunuse/difference-between-onblur-vs-ontouched-30fc</link>
      <guid>https://dev.to/yunuse/difference-between-onblur-vs-ontouched-30fc</guid>
      <description>&lt;blockquote&gt;
&lt;p&gt;Short Answer is:&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;&lt;strong&gt;onBlur&lt;/strong&gt; is an event that occurs when a field loses focus, which &lt;em&gt;can be used to trigger validation at that moment.&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;onTouched&lt;/strong&gt; is a state indicating whether a field has been interacted with and then left, &lt;em&gt;often used to control when to display validation messages.&lt;/em&gt;&lt;/p&gt;

&lt;blockquote&gt;
&lt;ul&gt;
&lt;li&gt;What is onBlur?&lt;/li&gt;
&lt;/ul&gt;
&lt;/blockquote&gt;

&lt;p&gt;&lt;strong&gt;Definition and Triggering Event:&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;onBlur is an event handler that is activated when an input field loses focus. This occurs when a user moves away from an input field after interacting with it.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Use in Form Validation:&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;It's commonly used in form validation to check a field's value against validation rules only when the user moves away from that field. This approach is less intrusive than validating every keystroke.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Practical Application:&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;This event is particularly useful when you want to validate a field after the user has finished entering data, avoiding constant validation during the typing process.&lt;/p&gt;

&lt;blockquote&gt;
&lt;ul&gt;
&lt;li&gt;What is onTouched?&lt;/li&gt;
&lt;/ul&gt;
&lt;/blockquote&gt;

&lt;p&gt;&lt;strong&gt;Definition and Role in Validation Libraries:&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Unlike onBlur, onTouched is not an event but a state or property used in form validation libraries, like React Hook Form. It flags whether a user has interacted with a field.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Functionality:&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;A field is considered "touched" once the user has focused on it and then moved away. It's instrumental in determining when to display validation errors.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Enhancing User Experience:&lt;/strong&gt;&lt;br&gt;
onTouched improves user experience by delaying error messages until the field has been interacted with, preventing an overload of messages upon form load.&lt;/p&gt;

&lt;p&gt;Understanding the roles and differences of onBlur and onTouched is vital in form design. While onBlur triggers validation when a field loses focus, onTouched indicates interaction with the field, helping in strategic display of validation messages. Together, they ensure a balance between providing immediate feedback and not overwhelming users with premature validation errors. Implementing these effectively can significantly enhance the user interaction and experience with your forms.&lt;/p&gt;

&lt;p&gt;Both onBlur and onTouched are essential tools in a developer’s arsenal for creating responsive and user-friendly web forms. Knowing when and how to use them can make a substantial difference in how users perceive and interact with your web forms.&lt;/p&gt;

</description>
      <category>javascript</category>
      <category>webdev</category>
      <category>react</category>
      <category>programming</category>
    </item>
    <item>
      <title>Laravel 9 İle Sıfırdan 90 Saatlik Uygulama Geliştirme Tecrübem</title>
      <dc:creator>Yunus</dc:creator>
      <pubDate>Wed, 16 Mar 2022 15:21:02 +0000</pubDate>
      <link>https://dev.to/yunuse/laravel-9-ile-sifirdan-90-saatlik-uygulama-gelistirme-tecrubem-3o4f</link>
      <guid>https://dev.to/yunuse/laravel-9-ile-sifirdan-90-saatlik-uygulama-gelistirme-tecrubem-3o4f</guid>
      <description>&lt;p&gt;Moneo adlı şirkette stajımın 4. haftasındayım. Stajımın 2. haftasında Laravel ile sepetsiz marketplace diyebileceğimiz bir uygulama geliştirmeye başladım. Bu yazımda yaklaşık 90 saat süren Laravel tecrübemi sizlere aktarmaya çalışacağım.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;1) Windows'a Php Kurulumu&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Birçok php geliştiricisinin aksine ben Windowsta çalışıyorum. Bunun sebebi olarak hem Windowsta daha rahat olduğumu hem de daha önceden yaşadığım Linux tecrübelerinde işletim sistemini kurcalarken yaşadığım problemlerin beni yavaşlatması olduğunu söyleyebilirim. Bu bağlamda Windowsta hızlıca kurmanız gerkenleri listeleyeyim &lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;XAMPP&lt;/strong&gt;- tamamiyle ücretsiz, yüklenmesi kolay Apache dağıtımı olup MariaDB, PHP ve Perl içerir.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Composer&lt;/strong&gt;- PHP ile uygulama geliştirirken olmazsa olmazımız, paket yöneticimiz.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Node.js&lt;/strong&gt;- içerisinde Npm ile gelen Node.js kurulumu sonrası Npm'i JavaScript paket yöneticisi olarak bizlere sunuyor.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;&lt;em&gt;Bu kadar!&lt;/em&gt;&lt;/strong&gt; &lt;br&gt;
Windows ile Php geliştirmeye başlamak aslında bu kadar kolay, daha sonrasında favori ide'niz ile php geliştirmeye hemen başlayabilirsiniz. &lt;/p&gt;

&lt;p&gt;&lt;strong&gt;2) İlk Laravel Projemizi Oluşturmak&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Php ortamını Windows'a kurduktan sonra Cmd ekranını açıp bir kereliğe mahsus&lt;br&gt;
&lt;code&gt;composer global require laravel/installer&lt;/code&gt;&lt;br&gt;
komutunu çalıştırıyoruz.&lt;br&gt;
Artık bilgisayarınızdaki tüm kullanıcılara Laravel'i tanıttığımızı söylebiliriz. Bundan sonra ise istediğiniz dizinde oluşturduğunuz klasörün içerisinde girip Cmd üzerinden &lt;code&gt;laravel new&lt;/code&gt; diyerek yeni projenizi oluşturabilirsiniz. Ben projemin adını iSotStore olarak belirlediğimden&lt;br&gt;
&lt;code&gt;laravel new iSotStore&lt;/code&gt;&lt;br&gt;
diyerek projemi oluşturuyorum. Laravelin bizlere vermiş olduğu &lt;strong&gt;"Build something amazing."&lt;/strong&gt; mesajıyla birlikte projemizi idemizde açıp, geliştirmeye başlıyoruz.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;3) İlk Adımlarımız&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Ben projeyi oluşturduktan hemen sonra bir Tema seçip bunu parçalayarak projeme giydirdiğimi söyleyebilirim.&lt;br&gt;
&lt;strong&gt;&lt;em&gt;Peki nedir bu parçalamak ?&lt;/em&gt;&lt;/strong&gt;&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Şöyleki laravel geliştirirken MVC yapımızda View'larımızı Blade Templates olarak tanımlıyoruz. Laravel içerisinde bulunan bu template engine bize birçok olanak sağlıyor. &lt;br&gt;
Örneğin, seçtiğimiz tema içerisinde sürekli aynı kalacak olan Header, Footer vb. sayfaları farklı bladeler içerisinde tanımlayıp, bladelerimizdeki kod tekrarından kaçınarak, hem daha temiz bir görüntü hem de okunabilirliği yüksek sayfalar oluşturmamızı sağlıyor.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Benim proje boyunca kullandıklarım'ı:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;yield()&lt;/li&gt;
&lt;li&gt;extends()&lt;/li&gt;
&lt;li&gt;include()&lt;/li&gt;
&lt;li&gt;section()&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;şeklinde sıralayabiliriz.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;4) Authentication&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Temamızı giydirdik, sayfalarımız hazır, artık back-end geliştirmelerini tanımlayıp sayfalarımıza işlev vermek istiyoruz, peki kullanıcı giriş sistemi ne olacak ? Laravel bunun için ne sunuyor ?&lt;br&gt;
Aslında burada birden fazla seçeneğiniz bulunuyor, hepsini ücretsiz olarak kullanabileceğiniz &lt;a href="https://laravel.com/docs/9.x/starter-kits#laravel-breeze"&gt;Laravel Breeze&lt;/a&gt;, &lt;a href="https://laravel.com/docs/9.x/starter-kits#laravel-jetstream"&gt;Laravel Jetstream&lt;/a&gt; ve &lt;a href="https://laravel.com/docs/9.x/fortify"&gt;Laravel Fortify&lt;/a&gt; bulunuyor. Ben ufak bir araştırma sonrası birçok işi hızlıca çözüp bana hızlı bir başlangıç sunacağını düşündüğüm için Jetstream kullandım.&lt;/p&gt;

&lt;p&gt;Düşündüğüm gibi de oldu açıkcası, Jetstream hızlı bir şekilde projeme kurulduktan sonra bana sunduğu sayfalarla birlikte onu kullanmamı sağladı. Ama her ne kadar hızlı bir başlangıç kiti olarak gelse de üzerinde özelliştirme yapmak için yaklaşık 10 saatimi harcadığımı söyleyebilirim :) &lt;/p&gt;

&lt;p&gt;Özelleştirdiğim sayfaları ve nasıl yaptığımı bu başlığın alt başlıkları olarak gelin hep beraber inceleyelim&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;4.1. Two-Factor Authentication'ı devre dışı bırakma&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;&lt;code&gt;config/fortify.php&lt;/code&gt; içerisinde bulabileceğiniz &lt;code&gt;features&lt;/code&gt; array'i içerisinde &lt;code&gt;Features::twoFactorAuthentication&lt;/code&gt; metodunu yorum satırına alarak hızlıca devre dışı bırakabiliyorsunuz. Ne kadar hızlı değil mi ?&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;4.2. Kendi Login&amp;amp;Register Formlarımız Üzerinden Authenticate Olmak&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Ben şahsen gidip dökümantasyonunu okumak yerine, Jetstream'in kendi sayfasında bunu nasıl çözdüğüne bakıp, aynısını kendi oluşturduğum form üzerinden yapmak istedim. Jetstream'i kurduktan sonra oluşturduğu bir çok blade'i siz de göreceksiniz. Örneğin: login.blade.php içerisine girip baktığımızda Post metodu ile gönderdiği form'u 'login' adındaki route üzerinden geçirerek Authenticate olmanızı sağladığını görebilirsiniz. Burada dikkat etmeniz gerekecek tek nokta, gönderdiği inputların name attributelarını aynı şekilde kullanmak, session mesajlarını da &lt;code&gt;Session::get('success')&lt;/code&gt; şeklinde yakalamaya çalışmaktansa &lt;code&gt;session('status')&lt;/code&gt; ile yakalayıp sonucun ne döndüğünü görmek.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;4.3. Şifre Güncelleme Formu oluşturmak&lt;/strong&gt;&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Yukarıda bahsettiğim 10 saatlik kısmın 6 saatini bu form yemiştir diyebiliriz. Ama yaptığım hataları okuduktan sonra, aynı hataları yapmadan işinizi hızlıca çözeceğinizi umuyorum.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Burada da aynı şekilde Jetstream'in şifre güncelleme formunda neler yaptığına bakacak olursak, tek göreceğimiz şey &lt;code&gt;&amp;lt;x-jet-form-section submit="updatePassword"&amp;gt;&lt;/code&gt; bu livewire tag'i olacak. Açıkcası burası bana oldukça kafa karıştırıcı gelmişti çünkü herhangi bir route ismi görememiştim. İlk iş olarak internette bunu nasıl yapacağımı araştırıp, baya vakit öldürdükten sonra kimsenin böyle bir şey yapmadığı, yaptıysa bile internette paylaşmadığını gördüm. &lt;/p&gt;

&lt;p&gt;Aklıma route listesine bakıp Update.Password gibi bir şey yakalayıp, bu route üzerinden PUT isteği atabileceğim geldi ve öyle de yaptım. &lt;code&gt;php artisan route:list&lt;/code&gt; komutuyla listelediğim route list üzerinden &lt;code&gt;'user-password.update'&lt;/code&gt;'e giriş yapmış kullanıcın id'si ile birlikte istek atmayı birçok kez denedim ama hiçbir geri dönüş almadan sayfanın kendini yenileyip durduğunu gördüm.&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Bu arada blade içerisinden PUT isteği gönderirken &lt;code&gt;&amp;lt;form method="post"&amp;gt;&lt;/code&gt; şeklinde POST attributesi ile form gönderip formun içerisinde &lt;code&gt;@method('PUT')&lt;/code&gt; yazdığımızı da belirteyim.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Yaptığım hatalara gelecek olursak, yine yukarıda belirtiğim &lt;code&gt;name&lt;/code&gt; attributelarını yanlış yazıp hata mesajlarını &lt;code&gt;@foreach ($errors-&amp;gt;all() as $error)&lt;/code&gt; şeklinde yakalamaya çalıştığımdan, ne şifremi güncelleyebiliyordum, ne hata mesajlarını görüntüleyebiliyordum. &lt;strong&gt;Çözüm&lt;/strong&gt; olarak ise &lt;code&gt;name&lt;/code&gt; attributelarını düzelttikten sonra hata mesajlarını &lt;code&gt;@foreach ($errors-&amp;gt;updatePassword-&amp;gt;all() as $error)&lt;/code&gt; şeklinde yakalayıp uzun uğraşlar sonucu şifremi güncelleyebildim :) Burada &lt;code&gt;updatePassword&lt;/code&gt; error bag'inin nereden geldiğini görmek isterseniz &lt;code&gt;app\Actions\Fortify\UpdatePassword.php&lt;/code&gt; içerisine bakmanız gerekiyor. &lt;/p&gt;

&lt;p&gt;&lt;strong&gt;5) CRUD İşlemleri&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Daha öncesinde SpringBoot, .Net kullanan biri olarak bana soracak olursanız Laravel'de işler çok daha kolay. Özellikle .Net'de tekrar tekrar oluşturduğunuz .cs dosyaları içersine yazdığınız aynı kodlardan kurtuluyorsunuz. Modeliniz oluşturduktan sonra tek yapmanız gereken ilgili Controller üzerinden modelinizi çağırarak işlemler yapmak. Index metodunda tüm verilerinizi listelemek mi istiyorsunuz &lt;code&gt;Category:all()&lt;/code&gt;, sizin için sayfalama yapmasını mı istiyorsunuz &lt;code&gt;Category:paginate(5)&lt;/code&gt; bitti. Tekrar tekrar her methodun üstüne Get mi Post mu, id mi alır ne döner binlerce Annotation tanımlamaktan kurtuluyorsunuz. Tamam burada da bir metodun Post ile mi Get ile mi çalışacağı belirtiliyor ama tamamen ayrı bir sayfada routinglerinizi ayarlamak için oluşturularn &lt;code&gt;web.php&lt;/code&gt; üzerinde. O yüzden daha temiz bir controller yapısıyla karşı karşıya kalıyoruz diyebilirim. &lt;/p&gt;

&lt;p&gt;Ayrıca, projeye başlarken sadece CRUD işlemleri yapacağımı sanmıştım ama takım arkadaşlarım sağolsun, metodlarımı url üzerinden manipüle edebileceklerini gördüğümden ilk defa bu uygulamamda Controller üzerinde aklıma gelen tüm senaryolara karşı kontrol yapıp bunu kodlarken buldum kendimi :)&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;6) Validation&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Laravel ile validation yaparken direkt olarak controller'in içerisine kurallarımızı tanımlamıyoruz. Bunun yerine oluşturacağımız Request sınıfına Validation kurallarımızı ve mesajlarımızı tanımlıyoruz. &lt;code&gt;php artisan make:request CategoryStoreRequest&lt;/code&gt; şeklinde oluşturduğumuz Request sınıfını dilediğiniz gibi düzenleyebilirsiniz.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;7) View Composer&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Benim proje için şöyle bir ihtiyacım doğdu. Projenin header kısmında kategorileri listelediğim bir yapım var. Bu kategori isimleri header'e veritabanından tüm kategori isimleri şeklinde geliyor. Bunun için gidip bir HeaderController oluşturup daha sonra bunu view'a return etmiyoruz. Benim de laravel ile birlikte tanıştığım View Composer yapısı ile birlikte oluşturacağımız değişkeni istediğimiz viewlar üzerinde paylaşabiliyoruz.&lt;/p&gt;

&lt;p&gt;Örneğin: Ben App\ViewComposers\ altında CategoryCompser adlı sınıfı oluşturdum, bu sınıf içerisinde Category Modelimden $categories adlı değişkene tüm kategorilerimi çekip&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;public function compose(View $view)
    {
        $view -&amp;gt; with('categories', $this-&amp;gt;categories-&amp;gt;all());
    }
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;diyerek bu değişkeni global olarak projede paylaştım. Daha sonrasında ise &lt;code&gt;ViewServiceProvider&lt;/code&gt; içerisinde bu sınıfımı &lt;code&gt;View::composer('main.data.header', CategoryComposer::class);&lt;br&gt;
&lt;/code&gt; diyerek tanıttım. &lt;/p&gt;

&lt;p&gt;Bu işlemlerin ardından artık Header içerisinden mevcut kategorilerime &lt;code&gt;$categories&lt;/code&gt; değişkeni üzerinden erişebilirim.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;8) Blade İçerisindeki Bazı Kontroller&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Bu başlıkta Blade içerisinde yaptığım bazı kontrollerden bahsedeceğim. Örneğin kullanıcının giriş yapıp yapmadığı, giriş yapmış kullanıcının mevcut sayfada yetkisinin olup olmadığı gibi. Daha öncesinde böyle bir proje geliştirme fırsatım olmadığından yaptıklarımı Best Practices olarak sizlere sunamıyorum ama işimi çözme konusunda hem Blade templates hem laravel çok yardımcı oldu diyebilirim :)&lt;/p&gt;

&lt;p&gt;Hızlıca bakacak olursak&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;Kullanıcının giriş yapıp yapmadığı:&lt;br&gt;
&lt;code&gt;@if (Route::has('login'))&lt;/code&gt; veya &lt;code&gt;@if (Route::has('register'))&lt;/code&gt; ile kontrol edilebiliyor&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Giriş yapmış kullanıcının bilgileri:&lt;br&gt;
&lt;code&gt;Auth::user()&lt;/code&gt; ile alınabiliyor örneğin id'si &lt;code&gt;Auth::user()-&amp;gt;id&lt;/code&gt; &lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Listelenen ürünün kullanıcıya ait olup olmadığı:&lt;br&gt;
&lt;code&gt;@if(Auth::user()-&amp;gt;whereId(Auth::id())-&amp;gt;with('shops')-&amp;gt;get()-&amp;gt;pluck('shops')-&amp;gt;first()-&amp;gt;id == $listing-&amp;gt;shops-&amp;gt;id)&lt;/code&gt;&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;gibi kontroller ile sayfalarınızdaki görüntülenen içerikler üzerinde hakimiyetiniz kolaylıkla oluyor diyebilirim.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;9) Uygulamamızı Yayına Almak&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Onlarca saatin ardından uygulamamızı localde iyice test ettikten sonra insanlara göstermek için yayına almamız gerekiyor. Şahsen daha önce bu konuda hiçbir tecrübesi olmayan biri olarak hızlıca bir laravel projesini nasıl yayına alırız bakalım.&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;Eğer öğrenciyseniz GitHub öğrenci paketine üye olun.&lt;/li&gt;
&lt;li&gt;GitHub öğrenci paketinden 100$ değerindeki digitalocean hediye çekinizi alın.&lt;/li&gt;
&lt;li&gt;
&lt;a href="https://godaddy.com/"&gt;GoDaddy&lt;/a&gt; üzerinden kendinize ait bir domain satın alın Örneğin: &lt;a href="http://yunuselci.com/"&gt;yunuselci&lt;/a&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;a href="https://www.youtube.com/watch?v=ww_oVrL9ohA"&gt;Deploy Laravel Project On Live Server&lt;/a&gt; bu videodaki adımları dikkatlice takip edin.&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;Adımları düzgün yaptığınız takdirde uygulamanız yayına hazır olacaktır ama linkini verdiğim videodaki adımları takip ederken her şeyi körü körüne kopyalamaktan kaçının. Örneğin sizin Php sürümünüz farklı olabilir, bağlandığınız uzak sunucuya, projenizdeki &lt;code&gt;composer.json&lt;/code&gt; dosyası içerisindeki &lt;code&gt;require&lt;/code&gt; php sürümünü kurduğunuzdan emin olun. &lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Kapanış:&lt;/strong&gt;&lt;br&gt;
Sıfırdan bir Laravel projesi oluşturmak aslında okuduğunuz kadar kolay. &lt;/p&gt;

&lt;p&gt;Ben sıfırdan açıp bir kurs izleyerek bir şeyleri öğrendiğimi söyleyemem ama 4. Sınıfa kadar gerek daha önceki staj tecrübelerim, gerekse değerli hocalarımın bana öğretmeye çalıştığı yazılım geliştirme sürecini anladıkça, teknolojiden bağımsız olarak, neyi nasıl geliştireceğini öğrenip, bildikten sonra kullanacağınız her teknoloji için açıp yeni bir kurs izlemiyorsunuz.Yapacağınız şeyleri yaparken kullanacağınız teknolojinin gereksinimlerini, kısıtlamalarını, dökümantasyonunu inceledikten sonra bir proje oluşturup kodlamaya başlıyorsunuz :) &lt;/p&gt;

&lt;p&gt;Herkese iyi çalışmalar dilerim, okuduğunuz için teşekkürler :)&lt;/p&gt;

</description>
      <category>webdev</category>
      <category>laravel</category>
      <category>beginners</category>
      <category>programming</category>
    </item>
  </channel>
</rss>
