<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>JS &#8211; エンジニア見習い</title>
	<atom:link href="https://otonan-syusyoku.work/archives/tag/js/feed" rel="self" type="application/rss+xml" />
	<link>https://otonan-syusyoku.work</link>
	<description>三流プログラマー</description>
	<lastBuildDate>Sun, 25 Feb 2024 12:52:08 +0000</lastBuildDate>
	<language>ja</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=6.9.4</generator>

<image>
	<url>https://otonan-syusyoku.work/wp-content/uploads/2023/10/cropped-名称未設定のデザイン-16-32x32.png</url>
	<title>JS &#8211; エンジニア見習い</title>
	<link>https://otonan-syusyoku.work</link>
	<width>32</width>
	<height>32</height>
</image> 
	<item>
		<title>RESTful APIとSPAの関係についてReactとPHPで解説します</title>
		<link>https://otonan-syusyoku.work/archives/1674</link>
					<comments>https://otonan-syusyoku.work/archives/1674#respond</comments>
		
		<dc:creator><![CDATA[hrokig2]]></dc:creator>
		<pubDate>Sun, 25 Feb 2024 12:40:20 +0000</pubDate>
				<category><![CDATA[好きではないJS]]></category>
		<category><![CDATA[絶対に必要なIT基礎知識]]></category>
		<category><![CDATA[HTTP]]></category>
		<category><![CDATA[JS]]></category>
		<category><![CDATA[Laravel]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[React]]></category>
		<category><![CDATA[Vue]]></category>
		<category><![CDATA[セキュリティ]]></category>
		<guid isPermaLink="false">https://otonan-syusyoku.work/?p=1674</guid>

					<description><![CDATA[RESTful APIとは？ RESTful APIは、ウェブアプリケーションやウェブサービスで使われるプログラミングインターフェースです。 REST（Representational State Transfer）の原 [&#8230;]]]></description>
										<content:encoded><![CDATA[<h2>RESTful APIとは？</h2>
<p><img fetchpriority="high" decoding="async" src="https://otonan-syusyoku.work/wp-content/uploads/2024/02/DMARCを設定しなくちゃ-1.png" alt="What&#96;s up" width="1000" height="500" class="aligncenter size-full wp-image-1665" srcset="https://otonan-syusyoku.work/wp-content/uploads/2024/02/DMARCを設定しなくちゃ-1.png 1000w, https://otonan-syusyoku.work/wp-content/uploads/2024/02/DMARCを設定しなくちゃ-1-300x150.png 300w, https://otonan-syusyoku.work/wp-content/uploads/2024/02/DMARCを設定しなくちゃ-1-768x384.png 768w" sizes="(max-width: 1000px) 100vw, 1000px" /></p>
<p>RESTful APIは、ウェブアプリケーションやウェブサービスで使われるプログラミングインターフェースです。<br />
REST（Representational State Transfer）の原則に基づいて設計されており、ウェブ上のリソースへのアクセスや操作を統一的な方法で提供します。<br />
リソースはURLで識別され、HTTPメソッド（GET、POST、PUT、DELETEなど）を使ってアクセスされます。</p>
<p>[getpost id=&#8221;1672&#8243; cat_name=&#8221;1&#8243; date=&#8221;0&#8243;]</p>
<h2>SPA（シングルページアプリケーション）とは？</h2>
<p>SPAは、ユーザーがアプリケーションを操作する際にページの再読み込みをせずに、必要なデータのみをサーバーから非同期に取得し、動的にページの内容を更新するウェブアプリケーションの形式です。</p>
<p>これにより、<span class="sc_marker blue"><strong>従来のマルチページアプリケーションに比べてユーザーエクスペリエンスが向上します。</strong></span></p>
<p>僕が所属しているチームでも<strong>ページのリロードが嫌だというユーザーの使用感からSPAへの移行が少しづつ始まってきています</strong>。<br />
世間的にもSPAは流行っていますよね。（流行っているから偉いというわけではない。知ることが大事</p>
<h2>RESTful APIとSPAの関係性</h2>
<p><img decoding="async" src="https://otonan-syusyoku.work/wp-content/uploads/2024/02/Lets-GO.png" alt="Let&#96;s GO" width="1000" height="500" class="aligncenter size-full wp-image-1680" srcset="https://otonan-syusyoku.work/wp-content/uploads/2024/02/Lets-GO.png 1000w, https://otonan-syusyoku.work/wp-content/uploads/2024/02/Lets-GO-300x150.png 300w, https://otonan-syusyoku.work/wp-content/uploads/2024/02/Lets-GO-768x384.png 768w" sizes="(max-width: 1000px) 100vw, 1000px" /></p>
<p>SPAでは、<strong>ページの初回読み込み時にアプリケーションの全てのコード（HTML、CSS、JavaScript）がロード</strong>されます。</p>
<p>その後の<span class="sc_marker blue"><strong>ユーザーの操作によってデータが必要になる場合、SPAはRESTful APIを通じてサーバーからデータを非同期に取得</strong></span>します。<br />
<strong>このデータはJSONやXML形式で返され、JavaScriptを用いてクライアントサイドで処理され、ページの一部分だけが動的に更新</strong>されます。</p>
<p>このアーキテクチャにより、SPAはユーザーにスムーズで反応の良いインターフェイスを提供できます。</p>
<p><span class="sc_marker blue"><strong>RESTful APIはこのプロセスの背後にあるデータ通信の基盤となります。</strong></span></p>
<h2>PHPとReactを使った例</h2>
<p>ここでは、PHPで書かれた簡単なRESTful APIと、Reactを使ったSPAの例を示します。</p>
<h3>PHPによるRESTful API</h3>
<p>PHPで簡単なAPIエンドポイントを作成します。この例では、GETリクエストを受け取り、簡単なJSONデータを返します。</p>
<div class="dark bg-gray-950 rounded-md">
<div>
<pre class="line-numbers"><code class="language-php">&lt;?php 
    header('Content-Type: application/json');
    $response = ['message' =&gt; 'Hello, world!'];
    echo json_encode($response); 

<code>    // Response
    //{"message": "Hello, world!"}</code> ?&gt;</code></pre>
</div>
</div>
<p>このPHPスクリプトは、サーバーに配置してのようにアクセスすると<span style="background-color: #ffffff; color: #333333; font-family: 游ゴシック, YuGothic, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', Verdana, メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;">JSONが返されます。</span></p>
<h3>ReactによるSPA</h3>
<p>Reactで簡単なSPAを作成し、上記のAPIからデータを取得して表示します。</p>
<div class="dark bg-gray-950 rounded-md">
<div class="p-4 overflow-y-auto">
<pre class="line-numbers"><code class="language-js">import React, { useState, useEffect } from 'react';
import axios from 'axios';

function App() {
  const [message, setMessage] = useState('');

  useEffect(() =&gt; {
    axios.get('http://yourserver.com/index.php')
      .then(response =&gt; {
        setMessage(response.data.message);
      })
      .catch(error =&gt; console.error('There was an error!', error));
  }, []);

  return (
    &lt;div&gt;
      &lt;button&gt;{message}&lt;/button&gt;
    &lt;/div&gt;
  );
}

export default App;
</code></pre>
<p>このコードは、コンポーネントがマウントされた後にAPIからデータを取得し、取得したメッセージを表示します。<br />
React（クライアントサイド）とPHP（サーバーサイド）を使った、RESTful APIとSPAの基本的な連携を示しています。</p>
</div>
<p>今回のコードでは、データを取得して表示するだけのコードになっていますが、Event処理などによりリロードされることなく動的にページの内容を変更させることが可能です。</p>
<h2>セキュリティとパフォーマンスの考慮</h2>
</div>
<p>SPA（シングルページアプリケーション）とRESTful APIを使用する際には、セキュリティとパフォーマンスの両方に配慮することが重要です。<br />
以下では、これらの観点から基本的なガイドラインをいくつか紹介します。</p>
<h3>セキュリティ</h3>
<ol>
<li><strong>HTTPSを使用する<br />
</strong>データの暗号化を確実に行うため、APIとの通信には常にHTTPSを使用します。（当たり前です）<br />
これにより、中間者攻撃（MITM）のリスクを減らすことができます。</li>
<li><strong>CORSポリシーを適切に設定する<br />
</strong>クロスオリジンリソースシェアリング（CORS）ポリシーを適切に設定し、信頼できるオリジンからのリクエストのみを許可します。<br />
不適切なCORS設定は、セキュリティリスクを招く可能性があります。</li>
<li><strong>認証と認可<br />
</strong>JWT（JSON Web Tokens）やOAuthなどの堅牢な認証メカニズムを使用して、APIへのアクセスをセキュアに管理します。<br />
また、ユーザーの権限に基づいてアクセスを制御する認可も重要です。</li>
<li><strong>入力の検証とサニタイズ<br />
</strong> SQLインジェクションやクロスサイトスクリプティング（XSS）攻撃を防ぐため、サーバー側とクライアント側の両方で入力値の検証とサニタイズを行います。</li>
<li><strong>依存関係のセキュリティ<br />
</strong>使用するライブラリやフレームワークのセキュリティ脆弱性に注意し、定期的に更新を行い脆弱性を修正します。</li>
</ol>
<p>この辺の対策については過去に記事にしていますので時間ある人は読んでみてくださーい</p>
<p>[getpost id=&#8221;1618&#8243; cat_name=&#8221;1&#8243; date=&#8221;0&#8243;][getpost id=&#8221;1256&#8243; cat_name=&#8221;1&#8243; date=&#8221;0&#8243;]</p>
<h3>パフォーマンス</h3>
<ol>
<li><strong>コードの分割<br />
</strong>ユーザーが必要とするコードのみをダウンロードするように、コード分割（Code Splitting）を実装します。<br />
これにより、初期ロード時間を短縮できます。</li>
<li><strong>キャッシュ戦略の利用<br />
</strong>静的リソースやAPIレスポンスのキャッシュを適切に利用することで、パフォーマンスを向上させることができます。<br />
ブラウザのキャッシュやCDNの利用が有効です。</li>
<li><strong>遅延ローディング（Lazy Loading）<br />
</strong> 画像やコンポーネントなど、必要になるまでロードしないようにします。<br />
これにより、初期ロードのパフォーマンスを向上させることができます。</li>
<li><strong>APIの最適化<br />
</strong>不必要なデータの送受信を避けるため、APIのレスポンスをできるだけ小さく保ちます。<br />
また、必要なデータのみを取得するためのフィルタリングやページネーションをAPI側でサポートします。</li>
<li><strong>フロントエンドのパフォーマンス最適化<br />
</strong>Reactなどのフロントエンドフレームワークを使用する場合は、不要な再レンダリングを避け、メモ化（memoization）や仮想DOMの効率的な利用などのテクニックを活用します。</li>
</ol>
<p>セキュリティとパフォーマンスは、アプリケーションの設計と開発の初期段階から考慮する必要があります。<br />
これらの基本的なガイドラインを実践することで、ユーザーに安全で快適な体験を提供することができます。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://otonan-syusyoku.work/archives/1674/feed</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>[React] useStateとuseEffectってすごく便利じゃん</title>
		<link>https://otonan-syusyoku.work/archives/1382</link>
					<comments>https://otonan-syusyoku.work/archives/1382#respond</comments>
		
		<dc:creator><![CDATA[hrokig2]]></dc:creator>
		<pubDate>Thu, 17 Aug 2023 16:17:59 +0000</pubDate>
				<category><![CDATA[好きではないJS]]></category>
		<category><![CDATA[JS]]></category>
		<category><![CDATA[React]]></category>
		<category><![CDATA[脱3流プログラマー]]></category>
		<guid isPermaLink="false">https://otonan-syusyoku.work/?p=1382</guid>

					<description><![CDATA[今までjQueryで戦ってきたのですが、とうとう見切りをつけて次のステップに進もうとしているコテツです… Reactの考え方 React では、DOM 要素を直接操作する代わりに、React の状態管理やレンダリング方法 [&#8230;]]]></description>
										<content:encoded><![CDATA[<p>今までjQueryで戦ってきたのですが、とうとう見切りをつけて次のステップに進もうとしているコテツです…</p>
<h2>Reactの考え方</h2>
<p>React では、DOM 要素を直接操作する代わりに、React の状態管理やレンダリング方法を使用して操作を行うことが推奨されているとのこと。</p>
<h2>useState</h2>
<p>useState フックは、状態（state）を React コンポーネント内で管理するために使用します。状態は、コンポーネント内でのデータの変更を追跡し、自動的に再レンダリングするために使われます。</p>
<p>差分取って差分の分だけレンダリングするっぽいですね。楽だし早いね。</p>
<p>Reactの基本理念？である状態管理で差分を取るってのがuseStateの肝な気がする。</p>
<h2>useEffect</h2>
<p>コンポーネントのレンダリング後に実行される処理(データ)を管理するために使用します。</p>
<p>useEffect フックは第1引数に副作用の関数を受け取り、第2引数には、依存する値の配列を指定します。この配列に指定した値が変更された場合に副作用関数が再実行されます。</p>
<p>空の配列を指定することで、初回レンダリング時にのみ副作用関数が実行されることを意味します。</p>
<pre class="line-numbers"><code class="language-js">    const [csrfToken, setCsrfToken] = useState(null);
    useEffect(() =&gt; {
        // メタタグからトークンを取得
        const metaTag = document.querySelector('meta[name="csrf-token"]');
        if (metaTag) {
            setCsrfToken(metaTag.content);
        }
    }, []);</code></pre>
<p>なんとなくonloadっぽい。。。</p>
<h3>注意点</h3>
<h4>第二引数に何も指定しない</h4>
<p>無限ループ発生します。ローカル端末が燃えます。気をつけましょ。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://otonan-syusyoku.work/archives/1382/feed</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>【PHP】PHPのスプレッド構文とはなんぞや</title>
		<link>https://otonan-syusyoku.work/archives/1318</link>
					<comments>https://otonan-syusyoku.work/archives/1318#respond</comments>
		
		<dc:creator><![CDATA[hrokig2]]></dc:creator>
		<pubDate>Sun, 28 May 2023 03:15:57 +0000</pubDate>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[JS]]></category>
		<category><![CDATA[コーディング]]></category>
		<guid isPermaLink="false">https://otonan-syusyoku.work/?p=1318</guid>

					<description><![CDATA[スプレッド構文とは 配列やオブジェクトの要素を展開するための構文です。 この構文は、配列やオブジェクトをより簡潔かつ柔軟に操作するために使用されます。 スプレッド構文を使用すると、配列やオブジェクトの要素を取り出して、別 [&#8230;]]]></description>
										<content:encoded><![CDATA[<h2>スプレッド構文とは</h2>
<p>配列やオブジェクトの要素を展開するための構文です。</p>
<p>この構文は、配列やオブジェクトをより簡潔かつ柔軟に操作するために使用されます。</p>
<p>スプレッド構文を使用すると、配列やオブジェクトの要素を取り出して、別の配列やオブジェクトに組み込むことができます。<br />
配列の場合、要素を展開して別の配列に組み込むことができます。オブジェクトの場合、プロパティを展開して別のオブジェクトに組み込むことができます。</p>
<pre class="line-numbers"><code class="language-php">$test = [1, 2, 3];
$testUnion = [...$test, 4, 5, 6];

var_dump($testUnion); 
// [1, 2, 3, 4, 5, 6]</code></pre>
<pre class="line-numbers"><code class="language-php">$test = ['name' =&gt; 'tarou', 'age' =&gt; 30];
$testUnion = ['city' =&gt; 'Gifu', ...$person1];

var_dump($testUnion); 
// ['city' =&gt; 'Gifu', 'name' =&gt; 'tarou', 'age' =&gt; 30]
</code></pre>
<h2>使い所</h2>
<h3>複数の配列を結合したり、オブジェクトのプロパティを組み合わせたりする場合</h3>
<pre class="line-numbers"><code class="language-php">$test1 = [1, 2, 3];
$test2 = [4, 5, 6];
$testUniion = [...$numbers1, ...$numbers2];

var_dump($testUnion); 
// [1, 2, 3, 4, 5, 6]</code></pre>
<p>※array_merge()とやっていることは一緒。<br />
なので、基本的にarray_merge()を使用することは今後少なそう。</p>
<h3>配列やオブジェクトの一部の要素を変更する場合</h3>
<pre class="line-numbers"><code class="language-php">$original = [1, 2, 3, 4, 5];
$modified = [...array_slice($original, 0, 2), 6, ...array_slice($original, 3)];

var_dump($modified); 
//展開
array(5) {
[0]=&gt;
int(1)
[1]=&gt;
int(2)
[2]=&gt;
int(6)
[3]=&gt;
int(4)
[4]=&gt;
int(5)
}</code></pre>
<p>&nbsp;</p>
<h3>関数の引数として使用する場合</h3>
<pre class="line-numbers"><code class="language-php">function sum(...$numbers) {
  return array_sum($numbers);
}

$result = sum(1, 2, 3, 4, 5);

var_dump($result); 
//int(15)</code></pre>
<p>※シンプルに配列を渡せばいいのではないか？と思ったのですが、呼び出し元で渡している引数が無限に増えても対応できるので結構便利かもしれません。</p>
<h3>配列やオブジェクトのコピーを作成する場合</h3>
<pre class="line-numbers"><code class="language-php">$original = [1, 2, 3];
$copy = [...$original];

var_dump($copy); 
// [1, 2, 3]
</code></pre>
<h2>思う所</h2>
<h3>JSを使うPJならつかっても良いかな…？</h3>
<p>ES2015からJSでもスプレッド構文が出現しているとのことです。<br />
<a href="https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Operators/Spread_syntax">https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Operators/Spread_syntax</a></p>
<p>一応PHPの方が先に機能として発表しているのですが、何と言ってもJS様です。</p>
<p>JS様と統一性を持って記述ができるのが魅力かもしれませんね…</p>
<p>&nbsp;</p>
]]></content:encoded>
					
					<wfw:commentRss>https://otonan-syusyoku.work/archives/1318/feed</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>【Laravel】axiosを使った非同期通信が404になる</title>
		<link>https://otonan-syusyoku.work/archives/1270</link>
					<comments>https://otonan-syusyoku.work/archives/1270#respond</comments>
		
		<dc:creator><![CDATA[hrokig2]]></dc:creator>
		<pubDate>Mon, 06 Mar 2023 06:03:34 +0000</pubDate>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[JS]]></category>
		<category><![CDATA[Laravel]]></category>
		<category><![CDATA[Vue]]></category>
		<category><![CDATA[非同期通信]]></category>
		<guid isPermaLink="false">https://otonan-syusyoku.work/?p=1270</guid>

					<description><![CDATA[エラー内容 レスポンス： AxiosError {message: 'Request failed with status code 404', name: 'AxiosError', code: 'ERR_BAD_RE [&#8230;]]]></description>
										<content:encoded><![CDATA[<h2>エラー内容</h2>
<p>レスポンス：</p>
<pre class="line-numbers"><code class="language-js">AxiosError {message: 'Request failed with status code 404', name: 'AxiosError', code: 'ERR_BAD_REQUEST',</code></pre>
<p>&nbsp;</p>
<p>考えられる原因：</p>
<ul>
<li>ルーティングを間違えている</li>
<li>通信先のURLが間違えている</li>
</ul>
<p>&nbsp;</p>
<h2>404になる原因</h2>
<p>Routeの設定を行っているのにレスポンスがになってしまう。</p>
<p>解決方法はエラーの文言通り、ページが存在していない事が原因です。</p>
<h3>エラーになるコード</h3>
<p>routes/api.php</p>
<pre class="line-numbers"><code class="language-php">Route::get(
    '/test',
    [Test::class, 'test_function']
);</code></pre>
<p>&nbsp;</p>
<p>resources/js/components/EnduserSearchstore.vue</p>
<pre class="line-numbers"><code class="language-js">import axios from 'axios';

    export default {
        data() {
            return {
                users: {},
            }
        },
        methods: {
            getBigCategory() {
                axios.get('/api_search_storeCategory')
                    .then((response) =&gt; {
                        // this.users = response.data.users
                        response(console.log(response))
                    })
            }
        },
        created() {
            this.getBigCategory()
        }
    }</code></pre>
<p>&nbsp;</p>
<p>&nbsp;</p>
<h3>正常動作するコード</h3>
<p>routes/api.php</p>
<pre class="line-numbers"><code class="language-php">Route::get(
    '/test',
    [Test::class, 'test_function']
);</code></pre>
<p>&nbsp;</p>
<p>resources/js/components/EnduserSearchstore.vue</p>
<pre class="line-numbers"><code class="language-js">import axios from 'axios';

    export default {
        data() {
            return {
                users: {},
            }
        },
        methods: {
            getBigCategory() {
                axios.get('/api/test')
                    .then((response) =&gt; {
                        // this.users = response.data.users
                        response(console.log(response))
                    })
            }
        },
        created() {
            this.getBigCategory()
        }
    }</code></pre>
<p>&nbsp;</p>
<h3> 修正内容</h3>
<p>axiosでURLを指定している箇所を「<strong>axios.get(&#8216;/api/test&#8217;)</strong>」と指定してあげる。</p>
<p>Laravelでは、route/api.phpで指定したルーティングではデフォルトで接頭辞に「/api」が付くことになっているっぽいです。<br />
そのため、エラーになるコードではVue側で呼び出しているURLは存在しない遷移先となっています。</p>
<p>LaravelのAPIのルーティングはデフォルトが付くのを忘れないようにしましょう〜。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://otonan-syusyoku.work/archives/1270/feed</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
	</channel>
</rss>
