{"id":12064,"date":"2023-10-29T07:00:59","date_gmt":"2023-10-28T22:00:59","guid":{"rendered":"https:\/\/blog.capilano-fw.com\/?p=12064"},"modified":"2023-10-07T02:19:41","modified_gmt":"2023-10-06T17:19:41","slug":"livewire-3-%ef%bc%86-10%e5%80%8b%e3%81%ae%e6%9c%89%e5%90%8djs-%e3%83%a9%e3%82%a4%e3%83%96%e3%83%a9%e3%83%aa%e3%81%8c%e5%85%b1%e5%ad%98%e3%81%a7%e3%81%8d%e3%82%8b%e3%81%8b%e3%83%81%e3%82%a7%e3%83%83","status":"publish","type":"post","link":"https:\/\/blog.capilano-fw.com\/?p=12064","title":{"rendered":"livewire 3 \uff06 10\u500b\u306e\u6709\u540dJS \u30e9\u30a4\u30d6\u30e9\u30ea\u304c\u5171\u5b58\u3067\u304d\u308b\u304b\u30c1\u30a7\u30c3\u30af"},"content":{"rendered":"<p>\u3055\u3066\u3055\u3066\u3001\u3053\u306e\u9593 <a href=\"https:\/\/blog.capilano-fw.com\/?p=12043\">Laravel + Livewire 3 \u3067 CRUD \u3092\u5b9f\u88c5\u3057\u3066\u307f\u308b<\/a> \u3068\u3044\u3046\u8a18\u4e8b\u3092\u516c\u958b\u3057\u305f\u306e\u3067\u3059\u304c\u3001\u305d\u306e\u5f8c\u3068\u3042\u308b\u3053\u3068\u304c\u6c17\u306b\u306a\u3063\u3066\u3044\u307e\u3057\u305f\u3002<\/p>\n<p>\u305d\u308c\u306f\u30fb\u30fb\u30fb\u30fb\u30fb\u30fb<\/p>\n<p><strong style=\"font-size: 35px;\">\u4ed6\u306e JavaScript \u30d1\u30c3\u30b1\u30fc\u30b8\u304c\u4e00\u7dd2\u306b\u4f7f\u3048\u308b\u304b\u3069\u3046\u304b \ud83e\udd14<\/strong><\/p>\n<p>\u3067\u3059\u3002<\/p>\n<p><code>Livewire<\/code>\u81ea\u4f53\u306f\u3068\u3066\u3082\u5b8c\u6210\u3055\u308c\u305f\u611f\u304c\u3042\u308b\u30c6\u30af\u30ce\u30ed\u30b8\u30fc\u3060\u3068\u611f\u3058\u3066\u3044\u308b\u306e\u3067\u3059\u304c\u3001\u3068\u306f\u3044\u3048\u3001\u3042\u308b\u6a5f\u80fd\u3092\u4f5c\u308a\u305f\u3044\u5834\u5408\u306f<code>JavaScript<\/code>\u754c\u306b\u5b58\u5728\u3059\u308b\u512a\u79c0\u306a\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u4e00\u7dd2\u306b\u4f7f\u3044\u305f\u3044\u3068\u601d\u3046\u306e\u306f\u81ea\u7136\u306a\u3053\u3068\u3067\u3059\u3088\u306d\u3002<\/p>\n<p>\u305d\u3053\u3067\u2757<\/p>\n<p>\u4eca\u5f8c\u306e\u958b\u767a\u306e\u305f\u3081\u306b\u3082\u3001<code>Livewire 3<\/code>\u3068\u4ee5\u4e0b\u306e\u30d1\u30c3\u30b1\u30fc\u30b8\u304c\u4e00\u7dd2\u306b\u4f7f\u3048\u308b\u304b\u3069\u3046\u304b\u3092\u691c\u8a3c\u3057\u3066\u307f\u308b\u3053\u3068\u306b\u3057\u307e\u3057\u305f\u3002<\/p>\n<ul>\n<li>Chart.js\uff1a \u30b0\u30e9\u30d5<\/li>\n<li>FullCalendar\uff1a \u30ab\u30ec\u30f3\u30c0\u30fc<\/li>\n<li>DataTable\uff1a \u30ea\u30b9\u30c8\u8868\u793a<\/li>\n<li>CKEditor\uff1a \u30c6\u30ad\u30b9\u30c8\u30a8\u30c7\u30a3\u30bf<\/li>\n<li>Leaflet\uff1a \u5730\u56f3<\/li>\n<li>Day.js\uff1a \u65e5\u4ed8\u30fb\u6642\u9593<\/li>\n<li>Sortable\uff1a \u30c9\u30e9\u30c3\u30b0\u30fb\u30a2\u30f3\u30c9\u30fb\u30c9\u30ed\u30c3\u30d7<\/li>\n<li>Lodash\uff1a \u5404\u7a2e\u4fbf\u5229\u6a5f\u80fd<\/li>\n<li>SweetAlert2\uff1a \u30c0\u30a4\u30a2\u30ed\u30b0<\/li>\n<li>node-qrcode\uff1a QR\u30b3\u30fc\u30c9\u4f5c\u6210<\/li>\n<\/ul>\n<p>\u305c\u3072\u4f55\u304b\u306e\u53c2\u8003\u306b\u306a\u308a\u307e\u3057\u305f\u3089\u5b09\u3057\u3044\u3067\u3059\u3002\ud83d\ude0a\u2728<\/p>\n<p style=\"text-align: center;\"><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-11002 aligncenter\" src=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2022\/09\/no_10.png\" alt=\"\" width=\"370\" height=\"290\" srcset=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2022\/09\/no_10.png 370w, https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2022\/09\/no_10-300x235.png 300w\" sizes=\"auto, (max-width: 370px) 100vw, 370px\" \/>\u300c\u3048\u3048\u3063\uff01<br \/>\n\u82f1\u8a9e\u306e AR \u3068 ER \u306e<br \/>\n\u767a\u97f3\u3066\u5225\u306a\u306e\u2757\u2753\u300d<\/p>\n<p><strong>\u958b\u767a\u74b0\u5883\uff1a<\/strong> Laravel 10.x\u3001Livewire 3<\/p>\n<h1>\u524d\u63d0\u3068\u3057\u3066<\/h1>\n<p>\u4eca\u56de\u4f7f\u7528\u3059\u308b<code>JS<\/code>\u30d1\u30c3\u30b1\u30fc\u30b8\u306f<code>npm<\/code>\u3067\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u3066<code>Vite<\/code>\u3067\u30d3\u30eb\u30c9\u3057\u3066\u304b\u3089\u4f7f\u3046\u3082\u306e\u3068\u3057\u307e\u3059\u3002\uff08\u672c\u756a\u74b0\u5883\u3092\u610f\u8b58\u3057\u307e\u3057\u305f\ud83d\udc4d\uff09<\/p>\n<p>\u305d\u306e\u305f\u3081\u3001\u5404\u691c\u8a3c\u306b\u306f\u30d1\u30c3\u30b1\u30fc\u30b8\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3068<code>Vite<\/code>\u306e\u8a2d\u5b9a\u3092\u8ffd\u52a0\u3057\u3066\u304a\u304d\u307e\u3059\u306e\u3067\u3001\u30d3\u30eb\u30c9\u3057\u3066\u4f7f\u7528\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<p>\u307e\u305f\u3001<code>Livewire 3<\/code>\u306f\u30d5\u30eb\u30da\u30fc\u30b8\u30fb\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u4f7f\u3044\u307e\u3059\u3002<\/p>\n<p>\u305d\u306e\u305f\u3081\u3001\u30ec\u30a4\u30a2\u30a6\u30c8\u30fb\u30d5\u30a1\u30a4\u30eb\u306b\u306f<code>@vite()<\/code>\u3092\u30bb\u30c3\u30c8\u3057\u3066\u304b\u3089\u5b9f\u65bd\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<div>\n<pre>&lt;!DOCTYPE html&gt;\r\n&lt;html lang=\"{{ str_replace('_', '-', app()-&gt;getLocale()) }}\"&gt;\r\n&lt;head&gt;\r\n    &lt;meta charset=\"utf-8\"&gt;\r\n    &lt;meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\"&gt;\r\n\r\n    &lt;title&gt;{{ $title ?? config('app.name') }}&lt;\/title&gt;\r\n    <strong>@vite(['resources\/css\/app.css', 'resources\/js\/app.js'])<\/strong>\r\n&lt;\/head&gt;\r\n&lt;body class=\"p-5\"&gt;\r\n\r\n&lt;!-- \u7701\u7565 --&gt;\r\n\r\n&lt;\/body&gt;\r\n&lt;\/html&gt;<\/pre>\n<\/div>\n<p>\u307e\u305f\u3001<code>Laravel<\/code>\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u5f8c\u306e\u307e\u3063\u3055\u3089\u306a\u72b6\u614b\u3067\u306f<code>TailwindCSS<\/code>\u304c\u5165\u3063\u3066\u3044\u306a\u3044\u306e\u3067\u3001\u3053\u3053\u3082\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u3066\u304a\u304d\u307e\u3059\u3002\uff08<a href=\"#install_tailwindcss\">\u304a\u307e\u3051\uff1aTailwindCSS\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b<\/a>\u3092\u53c2\u8003\u306b\u3057\u3066\u304f\u3060\u3055\u3044\uff09<\/p>\n<p>\u203b \u78ba\u304b<code>Laravel Breeze<\/code>\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b\u3068<code>TailwindCSS<\/code>\u304c\u81ea\u52d5\u3067\u5165\u3063\u3066\u304f\u308b\u306e\u3067\u305d\u3063\u3061\u3067\u3082<code>OK<\/code>\u304b\u3082\u3057\u308c\u307e\u305b\u3093\u3002<\/p>\n<p>\u307e\u305f\u3001<code>Livewire<\/code>\u304c\u64cd\u4f5c\u3055\u308c\u305f\u5834\u5408\u306e\u6319\u52d5\u3082\u8abf\u3079\u305f\u3044\u306e\u3067\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u3064\u304f\u3063\u3066\u4ee5\u4e0b\u306e\u30d5\u30a9\u30fc\u30e0\u3092\u8a2d\u7f6e\u3057\u3001\u305d\u306e\u4e0b\u306b\u4eca\u56de\u30c1\u30a7\u30c3\u30af\u3059\u308b<code>JS<\/code>\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u30bb\u30c3\u30c8\u3057\u3066\u3044\u304f\u3053\u3068\u306b\u3057\u307e\u3059\u3002<\/p>\n<div>\n<pre>&lt;div&gt;\r\n\r\n    @if (session('message'))\r\n        &lt;div class=\"bg-green-100 border border-green-400 text-green-700 px-4 py-3 rounded mb-3\" role=\"alert\"&gt;\r\n            {{ session('message') }}\r\n        &lt;\/div&gt;\r\n    @endif\r\n\r\n    &lt;!-- \u30d5\u30a9\u30fc\u30e0 --&gt;\r\n    &lt;form wire:submit=\"save\"&gt;\r\n        &lt;input wire:model=\"email\" type=\"text\" id=\"title\" name=\"title\" class=\"mt-1 p-2 w-full rounded border mb-5\"&gt;\r\n        &lt;button type=\"submit\" class=\"bg-green-600 text-white px-4 py-2 rounded\"&gt;\u9001\u4fe1&lt;\/button&gt;\r\n    &lt;\/form&gt;\r\n\r\n    &lt;hr class=\"my-5\"&gt;\r\n\r\n    <strong>&lt;!-- \u3053\u3053\u306b\u5404 JS \u30d1\u30c3\u30b1\u30fc\u30b8\u306e HTML \u3092\u8a18\u8ff0\u3059\u308b --&gt;<\/strong>\r\n    \r\n    &lt;!-- JavaScript --&gt;\r\n    &lt;script&gt;\r\n\r\n        <strong>document.addEventListener('livewire:initialized', () =&gt; {<\/strong>\r\n\r\n<strong>            \/\/ \u3053\u3053\u306b\u5404 JS \u30d1\u30c3\u30b1\u30fc\u30b8\u306e\u30b3\u30fc\u30c9\u3092\u8a18\u8ff0\u3059\u308b<\/strong>\r\n\r\n<strong>        });<\/strong>\r\n\r\n    &lt;\/script&gt;\r\n\r\n&lt;\/div&gt;<\/pre>\n<\/div>\n<p>\u3067\u306f\u3072\u3068\u3064\u305a\u3064\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u2757<\/p>\n<h1>Chart.js\uff08\u30b0\u30e9\u30d5\uff09<\/h1>\n<p>\u307e\u305a\u306f\u3001<code>JavaScript<\/code>\u3067\u30b0\u30e9\u30d5\u3092\u4f7f\u3046\u5834\u5408\u306e\u30c7\u30d5\u30a1\u30af\u30c8\u30b9\u30bf\u30f3\u30c0\u30fc\u30c9\u3068\u3044\u3063\u3066\u3044\u3044<code>Chart.js<\/code>\u3067\u3059\u3002<\/p>\n<p><strong>\uff08\u30b3\u30de\u30f3\u30c9\uff09<\/strong><\/p>\n<div>\n<pre><strong>npm i chart.js -D<\/strong><\/pre>\n<p><strong>resources\/js\/bootstrap.js<\/strong><\/p>\n<\/div>\n<div>\n<pre><strong>import Chart from 'chart.js\/auto';<\/strong>\r\n<strong>window.Chart = Chart;<\/strong><\/pre>\n<\/div>\n<p><strong>\uff08\u691c\u8a3c\u7d50\u679c\uff09<\/strong><\/p>\n<p>\u4ee5\u4e0b\u306e\u30b3\u30fc\u30c9\u3067\u30da\u30fc\u30b8\u8aad\u307f\u8fbc\u307f\u6642\u306b\u30b0\u30e9\u30d5\u3092\u8868\u793a\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3057\u305f\u3002<\/p>\n<div>\n<pre>&lt;script&gt;\r\n\r\n    <strong>\/\/ Chart.js<\/strong>\r\n<strong>    const renderChart = () =&gt; {<\/strong>\r\n\r\n<strong>        const ctx = document.getElementById('myChart');<\/strong>\r\n<strong>        new Chart(ctx, {<\/strong>\r\n<strong>            type: 'bar',<\/strong>\r\n<strong>            data: {<\/strong>\r\n<strong>                labels: ['\u6708', '\u706b', '\u6c34', '\u6728', '\u91d1', '\u571f', '\u65e5'],<\/strong>\r\n<strong>                datasets: [{<\/strong>\r\n<strong>                    label: '# of Votes',<\/strong>\r\n<strong>                    data: [12, 19, 3, 5, 2, 3, 7],<\/strong>\r\n<strong>                }]<\/strong>\r\n<strong>            },<\/strong>\r\n<strong>        });<\/strong>\r\n\r\n<strong>    };<\/strong>\r\n\r\n    document.addEventListener('livewire:initialized', () =&gt; {\r\n\r\n        <strong>renderChart();<\/strong>\r\n\r\n    });\r\n\r\n&lt;\/script&gt;<\/pre>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-12065\" style=\"border: 3px solid #000;\" src=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_1.png\" alt=\"\" width=\"555\" height=\"460\" srcset=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_1.png 555w, https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_1-300x249.png 300w\" sizes=\"auto, (max-width: 555px) 100vw, 555px\" \/><\/p>\n<p>\u3057\u304b\u3057\u3001\uff08\u4ed6\u306e\u30d1\u30c3\u30b1\u30fc\u30b8\u3082\u305d\u3046\u3067\u3059\u304c\uff09\u518d\u30ec\u30f3\u30c0\u30ea\u30f3\u30b0\u3057\u305f\u3089\uff08\u30d5\u30a9\u30fc\u30e0\u9001\u4fe1\u3057\u305f\u3089\uff09\u30b0\u30e9\u30d5\u304c\u6d88\u3048\u3066\u3057\u307e\u3046\u3068\u3044\u3046\u73fe\u8c61\u304c\u3042\u308a\u307e\u3057\u305f\u3002<\/p>\n<p><code>DOM<\/code>\u304c\u6d88\u3048\u3066\u3057\u307e\u3046\u306e\u3067\u5f53\u305f\u308a\u524d\u3068\u8a00\u3048\u3070\u5f53\u305f\u308a\u524d\u306a\u306e\u3067\u3059\u304c\u3001\u3053\u308c\u3092\u89e3\u6d88\u3059\u308b\u305f\u3081\u306b\u306f<code>wire:ignore<\/code>\u3067<code>Livewire<\/code>\u306e\u7ba1\u7406\u304b\u3089\u5916\u3057\u3066\u304a\u304f\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n<div>\n<pre>&lt;canvas id=\"myChart\" <strong>wire:ignore<\/strong>&gt;&lt;\/canvas&gt;<\/pre>\n<\/div>\n<div>\n<h1>FullCalendar\uff08\u30ab\u30ec\u30f3\u30c0\u30fc\uff09<\/h1>\n<p>\u3053\u3061\u3089\u3082\u6709\u540d\u30d1\u30c3\u30b1\u30fc\u30b8\u306e<code>FullCalendar<\/code>\u3067\u3059\u3002<br \/>\n\u30ab\u30ec\u30f3\u30c0\u30fc\u3092\u3064\u304f\u308b\u3068\u304d\u306b\u52a9\u304b\u3063\u3066\u308b\u958b\u767a\u8005\u306f\u304d\u3063\u3068\u305f\u304f\u3055\u3093\u3044\u308b\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<p><strong>\uff08\u30b3\u30de\u30f3\u30c9\uff09<\/strong><\/p>\n<div>\n<pre><strong>npm install @fullcalendar\/core -D\r\nnpm install @fullcalendar\/daygrid -D\r\nnpm install @fullcalendar\/timegrid -D\r\nnpm install @fullcalendar\/list -D\r\n<\/strong><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<p><strong>resources\/js\/bootstrap.js<\/strong><\/p>\n<div>\n<pre><strong>\/\/ FullCalendar<\/strong>\r\n<strong>import { Calendar } from '@fullcalendar\/core';<\/strong>\r\n<strong>import dayGridPlugin from '@fullcalendar\/daygrid';<\/strong>\r\n<strong>import timeGridPlugin from '@fullcalendar\/timegrid';<\/strong>\r\n<strong>import listPlugin from '@fullcalendar\/list';<\/strong>\r\n<strong>import fullCalendarLocales from '@fullcalendar\/core\/locales-all';<\/strong>\r\n<strong>window.Calendar = Calendar;<\/strong>\r\n<strong>window.dayGridPlugin = dayGridPlugin;<\/strong>\r\n<strong>window.timeGridPlugin = timeGridPlugin;<\/strong>\r\n<strong>window.listPlugin = listPlugin;<\/strong>\r\n<strong>window.fullCalendarLocales = fullCalendarLocales;<\/strong><\/pre>\n<\/div>\n<div>\n<p><strong>\uff08\u691c\u8a3c\u7d50\u679c\uff09<\/strong><\/p>\n<p>\u4ee5\u4e0b\u306e\u30b3\u30fc\u30c9\u3067\u3046\u307e\u304f\u8868\u793a\u3067\u304d\u308b\u3088\u3046\u3067\u3057\u305f\u3002<\/p>\n<div>\n<pre>\/\/ FullCalendar\r\n<strong>const renderCalendar = () =&gt; {<\/strong>\r\n\r\n<strong>    const el = document.getElementById('calendar');<\/strong>\r\n<strong>    const calendar = new Calendar(el, {<\/strong>\r\n<strong>        plugins: [dayGridPlugin, timeGridPlugin, listPlugin],<\/strong>\r\n<strong>        initialView: 'dayGridMonth',<\/strong>\r\n<strong>        headerToolbar: {<\/strong>\r\n<strong>            left: 'prev,next today',<\/strong>\r\n<strong>            center: 'title',<\/strong>\r\n<strong>            right: 'dayGridMonth,timeGridWeek,listWeek'<\/strong>\r\n<strong>        },<\/strong>\r\n<strong>        locales: fullCalendarLocales,<\/strong>\r\n<strong>        locale: 'ja',\r\n        events: '\/json\/events.json'<\/strong>\r\n<strong>    });<\/strong>\r\n<strong>    calendar.render();<\/strong>\r\n\r\n<strong>};<\/strong>\r\n\r\ndocument.addEventListener('livewire:initialized', () =&gt; {\r\n\r\n    <strong>renderCalendar();<\/strong>\r\n\r\n});<\/pre>\n<\/div>\n<\/div>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-12068\" style=\"border: 3px solid #000;\" src=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_2.png\" alt=\"\" width=\"500\" height=\"564\" srcset=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_2.png 500w, https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_2-266x300.png 266w\" sizes=\"auto, (max-width: 500px) 100vw, 500px\" \/><\/p>\n<p>\u305f\u3060\u3057\u3001\u3084\u306f\u308a<code>wire:ignore<\/code>\u306f\u5fc5\u8981\u3067\u3059\u3002<\/p>\n<div>\n<pre>&lt;div id=\"calendar\" style=\"width:600px;\" <strong>wire:ignore<\/strong>&gt;&lt;\/div&gt;<\/pre>\n<\/div>\n<p>\u306a\u304a\u3001<code>events<\/code>\u306f\u4ee5\u4e0b\u306e<code>JSON<\/code>\u30d5\u30a1\u30a4\u30eb\u3092<code>public\/json<\/code>\u306b\u8a2d\u7f6e\u3057\u307e\u3057\u305f\u3002\uff08\u3053\u308c\u306f\u3001\u672c\u5bb6\u306e\u30b5\u30f3\u30d7\u30eb\u3092<code>ChatGPT<\/code>\u3067\u65e5\u672c\u8a9e\u5316\u3057\u305f\u3082\u306e\u3067\u3059\uff09<\/p>\n<p><strong>public\/json\/events.json<\/strong><\/p>\n<div>\n<pre><strong>[<\/strong>\r\n<strong>    {\"title\":\"\u7d42\u65e5\u30a4\u30d9\u30f3\u30c8\",\"start\":\"2023-10-01\"},<\/strong>\r\n<strong>    {\"title\":\"\u9577\u671f\u30a4\u30d9\u30f3\u30c8\",\"start\":\"2023-10-07\",\"end\":\"2023-10-10\"},<\/strong>\r\n<strong>    {\"groupId\":\"999\",\"title\":\"\u7e70\u308a\u8fd4\u3057\u30a4\u30d9\u30f3\u30c8\",\"start\":\"2023-10-09T16:00:00+00:00\"},<\/strong>\r\n<strong>    {\"groupId\":\"999\",\"title\":\"\u7e70\u308a\u8fd4\u3057\u30a4\u30d9\u30f3\u30c8\",\"start\":\"2023-10-16T16:00:00+00:00\"},<\/strong>\r\n<strong>    {\"title\":\"\u4f1a\u8b70\",\"start\":\"2023-10-04\",\"end\":\"2023-10-06\"},<\/strong>\r\n<strong>    {\"title\":\"\u30df\u30fc\u30c6\u30a3\u30f3\u30b0\",\"start\":\"2023-10-05T10:30:00+00:00\",\"end\":\"2023-10-05T12:30:00+00:00\"},<\/strong>\r\n<strong>    {\"title\":\"\u30e9\u30f3\u30c1\",\"start\":\"2023-10-05T12:00:00+00:00\"},<\/strong>\r\n<strong>    {\"title\":\"\u8a95\u751f\u65e5\u30d1\u30fc\u30c6\u30a3\u30fc\",\"start\":\"2023-10-06T07:00:00+00:00\"},<\/strong>\r\n<strong>    {\"url\":\"http:\/\/google.com\/\",\"title\":\"Google\u3078\u306e\u30ea\u30f3\u30af\",\"start\":\"2023-10-28\"},<\/strong>\r\n<strong>    {\"title\":\"\u30df\u30fc\u30c6\u30a3\u30f3\u30b0\",\"start\":\"2023-10-05T14:30:00+00:00\"},<\/strong>\r\n<strong>    {\"title\":\"\u30cf\u30c3\u30d4\u30fc\u30a2\u30ef\u30fc\",\"start\":\"2023-10-05T17:30:00+00:00\"},<\/strong>\r\n<strong>    {\"title\":\"\u30c7\u30a3\u30ca\u30fc\",\"start\":\"2023-10-05T20:00:00+00:00\"}<\/strong>\r\n<strong>]<\/strong><\/pre>\n<\/div>\n<h1>DataTable\uff08\u30ea\u30b9\u30c8\u8868\u793a\uff09<\/h1>\n<p><code>DataTable<\/code>\u306f\u30a6\u30a7\u30d6\u4e0a\u3067\u30c7\u30fc\u30bf\u30c6\u30fc\u30d6\u30eb\u3092\u52b9\u7387\u7684\u306b\u64cd\u4f5c\u3059\u308b\u305f\u3081\u306e\u3082\u306e\u3067\u3059\u3002<br \/>\n\u79c1\u81ea\u8eab\u3082\u904e\u53bb\u306b\u306f\u3088\u304f\u304a\u4e16\u8a71\u306b\u306a\u308a\u307e\u3057\u305f\u3002<\/p>\n<p><strong>\uff08\u30b3\u30de\u30f3\u30c9\uff09<\/strong><\/p>\n<div>\n<pre><strong>npm install datatables.net-dt -D<\/strong><\/pre>\n<\/div>\n<p><strong>resources\/js\/bootstrap.js<\/strong><\/p>\n<div>\n<pre>\/\/ DataTables\r\n<strong>import DataTable from 'datatables.net-dt';<\/strong>\r\n<strong>window.DataTable = DataTable;<\/strong><\/pre>\n<p><strong>resources\/css\/app.css<\/strong><\/p>\n<\/div>\n<div>\n<pre><strong>@import 'datatables.net-dt\/css\/jquery.dataTables.css';<\/strong><\/pre>\n<p>\u203b \u3054\u6ce8\u610f\uff1a <code>@tailwind<\/code>\u3088\u308a\u4e0a\u306b\u8a18\u8ff0\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\uff08\u4e00\u756a\u4e0a\u306b\u3057\u3066\u304a\u3051\u3070\u554f\u984c\u3042\u308a\u307e\u305b\u3093\uff09<\/p>\n<p>\uff08\u691c\u8a3c\u7d50\u679c\uff09<\/p>\n<p>\u3053\u308c\u3082\u4ee5\u4e0b\u306e\u30b3\u30fc\u30c9\u3067\u3046\u307e\u304f\u3044\u304d\u307e\u3057\u305f\uff01<\/p>\n<\/div>\n<div>\n<pre><strong>\/\/ DataTable<\/strong>\r\n<strong>const renderDataTable = () =&gt; {<\/strong>\r\n\r\n<strong>    new DataTable('#myTable', {<\/strong>\r\n<strong>        ajax: {<\/strong>\r\n<strong>            url: '\/json\/staff.json',<\/strong>\r\n<strong>            method: 'GET',<\/strong>\r\n<strong>            dataSrc: 'data'<\/strong>\r\n<strong>        },<\/strong>\r\n<strong>        columns: [<\/strong>\r\n<strong>            { data: 'name', title: '\u540d\u524d' },<\/strong>\r\n<strong>            { data: 'position', title: '\u5f79\u8077' },<\/strong>\r\n<strong>            { data: 'salary', title: '\u7d66\u4e0e' },<\/strong>\r\n<strong>            { data: 'start_date', title: '\u5165\u793e\u65e5' },<\/strong>\r\n<strong>            { data: 'office', title: '\u30aa\u30d5\u30a3\u30b9' },<\/strong>\r\n<strong>        ],<\/strong>\r\n<strong>    });<\/strong>\r\n\r\n<strong>};<\/strong>\r\n\r\ndocument.addEventListener('livewire:initialized', () =&gt; {\r\n\r\n<strong>    \/\/ DataTable<\/strong>\r\n<strong>    renderDataTable();<\/strong>\r\n\r\n});<\/pre>\n<\/div>\n<p>&nbsp;<\/p>\n<div>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-12071\" style=\"border: 3px solid #000;\" src=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_3.png\" alt=\"\" width=\"500\" height=\"308\" srcset=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_3.png 500w, https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_3-300x185.png 300w\" sizes=\"auto, (max-width: 500px) 100vw, 500px\" \/><\/p>\n<p>\u305f\u3060\u3057\u3001\u6c17\u3092\u3064\u3051\u306a\u3044\u3068\u3044\u3051\u306a\u3044\u306e\u304c\u3001<strong>\u300cwire:ignore\u300d\u3092\u3064\u3051\u308b\u5834\u6240<\/strong>\u3067\u3059\u3002<\/p>\n<p><code>Chart.js<\/code>\u3084<code>FullCalendar<\/code>\u306f\u300c\u672c\u4f53\u300d\u306b\u30bb\u30c3\u30c8\u3057\u3066\u304a\u3051\u3070\u554f\u984c\u3042\u308a\u307e\u305b\u3093\u3067\u3057\u305f\u304c\u3001<code>DataTable<\/code>\u306f\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u3072\u3068\u3064\u4e0a\u306e\u968e\u5c64\u306b\u30bb\u30c3\u30c8\u3057\u306a\u3044\u3068\u3046\u307e\u304f\u3044\u304d\u307e\u305b\u3093\u3067\u3057\u305f\u3002<\/p>\n<div>\n<pre>&lt;!-- \ud83d\udc47 wire:ignore \u306f\u3053\u3053 --&gt;\r\n&lt;div style=\"width:700px;\"<strong> wire:ignore<\/strong>&gt;\r\n    &lt;!-- \ud83d\udc47 \u672c\u4f53\u306f\u3053\u3053 --&gt;\r\n    <strong>&lt;table id=\"myTable\"&gt;&lt;\/table&gt;<\/strong>\r\n&lt;\/div&gt;<\/pre>\n<\/div>\n<\/div>\n<p>\u306a\u304a\u3001\u8868\u793a\u3059\u308b\u30c7\u30fc\u30bf\u306f<code>ajax<\/code>\u3067\u4ee5\u4e0b\u306e<code>JSON<\/code>\u3092\u8aad\u307f\u306b\u3044\u304f\u3088\u3046\u306b\u3057\u307e\u3057\u305f\u3002<\/p>\n<p><strong>public\/json\/staff.json<\/strong><\/p>\n<div>\n<pre><strong>{<\/strong>\r\n<strong>    \"data\": [<\/strong>\r\n<strong>        {<\/strong>\r\n<strong>            \"name\": \"\u7530\u4e2d\u592a\u90ce\",<\/strong>\r\n<strong>            \"position\": \"\u30b7\u30b9\u30c6\u30e0\u30a2\u30fc\u30ad\u30c6\u30af\u30c8\",<\/strong>\r\n<strong>            \"salary\": \"\u00a53,200,000\",<\/strong>\r\n<strong>            \"start_date\": \"2020\/01\/15\",<\/strong>\r\n<strong>            \"office\": \"\u6771\u4eac\"<\/strong>\r\n<strong>        },<\/strong>\r\n<strong>        {<\/strong>\r\n<strong>            \"name\": \"\u4f50\u85e4\u82b1\u5b50\",<\/strong>\r\n<strong>            \"position\": \"\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u30de\u30cd\u30fc\u30b8\u30e3\u30fc\",<\/strong>\r\n<strong>            \"salary\": \"\u00a52,500,000\",<\/strong>\r\n<strong>            \"start_date\": \"2019\/06\/20\",<\/strong>\r\n<strong>            \"office\": \"\u5927\u962a\"<\/strong>\r\n<strong>        },<\/strong>\r\n<strong>        {<\/strong>\r\n<strong>            \"name\": \"\u9234\u6728\u4e00\u90ce\",<\/strong>\r\n<strong>            \"position\": \"\u30c7\u30fc\u30bf\u30a2\u30ca\u30ea\u30b9\u30c8\",<\/strong>\r\n<strong>            \"salary\": \"\u00a51,800,000\",<\/strong>\r\n<strong>            \"start_date\": \"2021\/09\/10\",<\/strong>\r\n<strong>            \"office\": \"\u798f\u5ca1\"<\/strong>\r\n<strong>        }<\/strong>\r\n<strong>    ]<\/strong>\r\n<strong>}<\/strong><\/pre>\n<\/div>\n<p>\u3061\u306a\u307f\u306b\u3001<code>DataTable<\/code>\u306f\u73fe\u5728<code>jQuery<\/code>\u306a\u3057\u3067\u3082\u52d5\u304f\u3093\u3067\u3059\u306d\ud83d\udc4d<\/p>\n<h1>CKEditor 5\uff08\u30c6\u30ad\u30b9\u30c8\u30a8\u30c7\u30a3\u30bf\uff09<\/h1>\n<p>\u6587\u5b57\u3092\u592a\u5b57\u306b\u3057\u305f\u308a\u4e0b\u7dda\u3092\u3064\u3051\u305f\u308a\u3067\u304d\u308b\u3001\u3044\u308f\u3086\u308b\u300c<strong>\u30ea\u30c3\u30c1\u30a8\u30c7\u30a3\u30bf<\/strong>\u300d\u3068\u547c\u3070\u308c\u308b\u3082\u306e\u3067\u3059\u3002<\/p>\n<p>\u203b \u306a\u304a\u3001<code>CKEditor<\/code>\u3092<code>Vite<\/code>\u3067\u30d3\u30eb\u30c9\u3059\u308b\u306e\u306f\u307e\u3060\u672c\u683c\u904b\u7528\u3067\u306f\u306a\u3044\u3088\u3046\u306a\u306e\u3067\u304a\u6c17\u3092\u3064\u3051\u304f\u3060\u3055\u3044\u3002\uff082023.10.6 \u73fe\u5728\uff09\u8a73\u3057\u304f\u306f\u4ee5\u4e0b\u304b\u3089\u3002<\/p>\n<p><strong>\ud83d\udcdd \u53c2\u8003\u30da\u30fc\u30b8\uff1a<\/strong>\u00a0<a href=\"https:\/\/ckeditor.com\/docs\/ckeditor5\/latest\/installation\/advanced\/alternative-setups\/integrating-from-source-vite.html\" target=\"_blank\" rel=\"noopener\">Integrating from source using Vite<\/a><\/p>\n<p><strong>\uff08\u30b3\u30de\u30f3\u30c9\uff09<\/strong><\/p>\n<div>\n<pre><strong>npm install @ckeditor\/ckeditor5-theme-lark -D<\/strong>\r\n<strong>npm install @ckeditor\/ckeditor5-autoformat -D<\/strong>\r\n<strong>npm install @ckeditor\/ckeditor5-basic-styles -D<\/strong>\r\n<strong>npm install @ckeditor\/ckeditor5-block-quote -D<\/strong>\r\n<strong>npm install @ckeditor\/ckeditor5-editor-classic -D<\/strong>\r\n<strong>npm install @ckeditor\/ckeditor5-essentials -D<\/strong>\r\n<strong>npm install @ckeditor\/ckeditor5-heading -D<\/strong>\r\n<strong>npm install @ckeditor\/ckeditor5-link -D<\/strong>\r\n<strong>npm install @ckeditor\/ckeditor5-list -D<\/strong>\r\n<strong>npm install @ckeditor\/ckeditor5-paragraph -D<\/strong>\r\n<strong>npm install @ckeditor\/vite-plugin-ckeditor5 -D<\/strong><\/pre>\n<p><strong>vite.config.js<\/strong><\/p>\n<div>\n<pre>import { defineConfig } from 'vite';\r\nimport laravel from 'laravel-vite-plugin';\r\n\r\n\/\/ \ud83d\udc47 \u4ee5\u4e0b\u3092\u8ffd\u52a0\u3057\u307e\u3057\u305f\r\n<strong>import { createRequire } from 'node:module';<\/strong>\r\n<strong>const require = createRequire( import.meta.url );<\/strong>\r\n<strong>import ckeditor5 from '@ckeditor\/vite-plugin-ckeditor5';<\/strong>\r\n\r\nexport default defineConfig({\r\n    plugins: [\r\n        laravel({\r\n            input: ['resources\/css\/app.css', 'resources\/js\/app.js'],\r\n            refresh: true,\r\n        }),\r\n        <strong>ckeditor5({theme: require.resolve('@ckeditor\/ckeditor5-theme-lark')}) \/\/ \ud83d\udc48 \u3053\u3053\u3092\u8ffd\u52a0\u3057\u307e\u3057\u305f<\/strong>\r\n    ],\r\n    build: { chunkSizeWarningLimit: 1600, },\r\n});<\/pre>\n<p><strong>resources\/js\/bootstrap.js<\/strong><\/p>\n<div>\n<pre><strong>\/\/ CKEditor<\/strong>\r\n<strong>import { ClassicEditor as ClassicEditorBase } from '@ckeditor\/ckeditor5-editor-classic';<\/strong>\r\n<strong>import { Essentials } from '@ckeditor\/ckeditor5-essentials';<\/strong>\r\n<strong>import { Autoformat } from '@ckeditor\/ckeditor5-autoformat';<\/strong>\r\n<strong>import { Bold, Italic } from '@ckeditor\/ckeditor5-basic-styles';<\/strong>\r\n<strong>import { BlockQuote } from '@ckeditor\/ckeditor5-block-quote';<\/strong>\r\n<strong>import { Heading } from '@ckeditor\/ckeditor5-heading';<\/strong>\r\n<strong>import { Link } from '@ckeditor\/ckeditor5-link';<\/strong>\r\n<strong>import { List } from '@ckeditor\/ckeditor5-list';<\/strong>\r\n<strong>import { Paragraph } from '@ckeditor\/ckeditor5-paragraph';<\/strong>\r\n\r\n<strong>export default class ClassicEditor extends ClassicEditorBase {}<\/strong>\r\n\r\n<strong>ClassicEditor.builtinPlugins = [<\/strong>\r\n<strong>    Essentials,<\/strong>\r\n<strong>    Autoformat,<\/strong>\r\n<strong>    Bold,<\/strong>\r\n<strong>    Italic,<\/strong>\r\n<strong>    BlockQuote,<\/strong>\r\n<strong>    Heading,<\/strong>\r\n<strong>    Link,<\/strong>\r\n<strong>    List,<\/strong>\r\n<strong>    Paragraph<\/strong>\r\n<strong>];<\/strong>\r\n\r\n<strong>ClassicEditor.defaultConfig = {<\/strong>\r\n<strong>    toolbar: {<\/strong>\r\n<strong>        items: [<\/strong>\r\n<strong>            'heading',<\/strong>\r\n<strong>            '|',<\/strong>\r\n<strong>            'bold',<\/strong>\r\n<strong>            'italic',<\/strong>\r\n<strong>            'link',<\/strong>\r\n<strong>            'bulletedList',<\/strong>\r\n<strong>            'numberedList',<\/strong>\r\n<strong>            'blockQuote',<\/strong>\r\n<strong>            'undo',<\/strong>\r\n<strong>            'redo'<\/strong>\r\n<strong>        ]<\/strong>\r\n<strong>    },<\/strong>\r\n<strong>    language: 'en'<\/strong>\r\n<strong>};<\/strong>\r\n<strong>window.ClassicEditor = ClassicEditor;<\/strong><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<p>\u306a\u304a\u3001\u3082\u3057\u30d3\u30eb\u30c9\u3057\u305f\u3068\u304d\u306b\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u8b66\u544a\u304c\u51fa\u305f\u5834\u5408\u306f\u3001<\/p>\n<blockquote><p>[vite:css] Nested CSS was detected, but CSS nesting has not been configured correctly.<br \/>\nPlease enable a CSS nesting plugin *before* Tailwind in your configuration.<\/p><\/blockquote>\n<p><code>postcss.config.js<\/code> \u306b\u4ee5\u4e0b\u3092\u8a18\u8ff0\u3057\u3066\u304f\u3060\u3055\u3044\u3002\uff08\u3069\u3046\u3084\u3089\u30d7\u30e9\u30b0\u30a4\u30f3\u304c\u5148\u306b\u8aad\u307f\u8fbc\u307e\u308c\u3066\u3044\u306a\u3044\u3068\u3044\u3051\u306a\u3044\u3053\u3068\u304c\u539f\u56e0\u306e\u3088\u3046\u3067\u3059\uff09<\/p>\n<p><strong>postcss.config.js<\/strong><\/p>\n<div>\n<pre>export default {\r\n  plugins: {\r\n    <strong>'tailwindcss\/nesting': {}<\/strong>, \/\/ \u7a7a\u306e\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u3092\u8ffd\u52a0\u3057\u307e\u3057\u305f\r\n    tailwindcss: {},\r\n    autoprefixer: {},\r\n  },\r\n}<\/pre>\n<p><strong>\uff08\u691c\u8a3c\u7d50\u679c\uff09<\/strong><\/p>\n<p><code>CKEditor<\/code>\u3082\u3046\u307e\u304f\u52d5\u4f5c\u3059\u308b\u3088\u3046\u3067\u3057\u305f\uff01<\/p>\n<div>\n<pre><strong>const renderCkeditor = () =&gt; {<\/strong>\r\n\r\n<strong>    const el = document.querySelector('#editor');<\/strong>\r\n    ClassicEditor.create(el);\r\n\r\n};\r\n\r\ndocument.addEventListener('livewire:initialized', () =&gt; {\r\n\r\n<strong>    \/\/ CKEditor 5<\/strong>\r\n<strong>    renderCkeditor();<\/strong>\r\n\r\n});<\/pre>\n<\/div>\n<p>\u3084\u306f\u308a<code>wire:ignore<\/code>\u3092\u4f7f\u3046\u3068\u307b\u307c\u5e72\u6e09\u306f\u3057\u306a\u3044\u3088\u3046\u3067\u3059\u306d\ud83d\udc4d<\/p>\n<\/div>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-12072\" style=\"border: 3px solid #000;\" src=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_4.png\" alt=\"\" width=\"543\" height=\"329\" srcset=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_4.png 543w, https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_4-300x182.png 300w\" sizes=\"auto, (max-width: 543px) 100vw, 543px\" \/><\/p>\n<p>\u305f\u3060\u3057\u3001<code>DataTable<\/code>\u3068\u540c\u3058\u304f<code>wire:ignore<\/code>\u306f\u5916\u5074\u306b\u3064\u3051\u306a\u3044\u3068\u518d\u30ec\u30f3\u30c0\u30ea\u30f3\u30b0\u306e\u3068\u304d\u306b\u304a\u304b\u3057\u304f\u306a\u3063\u3066\u3057\u307e\u3046\u3088\u3046\u3067\u3057\u305f\u3002<\/p>\n<div>\n<pre>&lt;div style=\"width:500px;\"<strong> wire:ignore<\/strong>&gt;\r\n    <strong>&lt;div id=\"editor\"&gt;\r\n        &lt;p&gt;\u30c6\u30b9\u30c8&lt;\/p&gt;\r\n        &lt;p&gt;\u30c6\u30b9\u30c8\uff12&lt;\/p&gt;\r\n        &lt;p&gt;\u30c6\u30b9\u30c8\uff13&lt;\/p&gt;\r\n    &lt;\/div&gt;<\/strong>\r\n&lt;\/div&gt;<\/pre>\n<\/div>\n<h1>Leaflet\uff08\u5730\u56f3\uff09<\/h1>\n<p>\u7d9a\u3044\u3066\u3001\u5730\u56f3\u8868\u793a\u306e\u30d1\u30c3\u30b1\u30fc\u30b8<code>Leaflet<\/code>\u3067\u3059\u3002<\/p>\n<p>\u5730\u56f3\u306e\u57cb\u3081\u8fbc\u307f\u3067\u306f<code>Google Map<\/code>\u304c\u6700\u512a\u5148\u3067\u3057\u3087\u3046\u304c\u3001\uff08\u7121\u6599\u3067\uff09\u3044\u308d\u3044\u308d\u306a\u5730\u56f3\u306e\u64cd\u4f5c\u304c\u3067\u304d\u308b\u3088\u3046\u306b\u3059\u308b\u306b\u306f<code>Leaflet<\/code>\u4e00\u629e\u3068\u3044\u3046\u5370\u8c61\u3067\u3059\u3002<\/p>\n<p><strong>\uff08\u30b3\u30de\u30f3\u30c9\uff09<\/strong><\/p>\n<div>\n<pre><strong>npm install leaflet -D<\/strong><\/pre>\n<\/div>\n<p><strong>resources\/js\/bootstrap.js<\/strong><\/p>\n<div>\n<pre>\/\/ Leaflet\r\n<strong>import L from 'leaflet';<\/strong>\r\n<strong>import 'leaflet\/dist\/leaflet.css';<\/strong>\r\n<strong>import markerIcon from 'leaflet\/dist\/images\/marker-icon.png';<\/strong>\r\n<strong>window.markerIcon = markerIcon; \/\/ \u30de\u30fc\u30ab\u30fc\u306e\u30a2\u30a4\u30b3\u30f3<\/strong><\/pre>\n<p><strong>\uff08\u691c\u8a3c\u7d50\u679c\uff09<\/strong><\/p>\n<p>\u4ee5\u4e0b\u306e\u30b3\u30fc\u30c9\u3067\u3046\u307e\u304f\u5730\u56f3\uff08\u30de\u30fc\u30ab\u30fc\u4ed8\u304d\uff09\u3092\u8868\u793a\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3057\u305f\u3002<\/p>\n<div>\n<pre><strong>const renderLeaflet = () =&gt; {<\/strong>\r\n\r\n<strong>    const map = L.map('map').setView([35.680545109582106, 139.76822649218585], 13);<\/strong>\r\n<strong>    L.Marker.prototype.setIcon(L.icon({<\/strong>\r\n<strong>        iconUrl: markerIcon,<\/strong>\r\n<strong>        iconSize: [25, 41],<\/strong>\r\n<strong>    }))<\/strong>\r\n\r\n<strong>    L.tileLayer('https:\/\/tile.openstreetmap.org\/{z}\/{x}\/{y}.png', {<\/strong>\r\n<strong>        maxZoom: 19,<\/strong>\r\n<strong>        attribution: '&amp;copy; &lt;a href=\"http:\/\/www.openstreetmap.org\/copyright\"&gt;OpenStreetMap&lt;\/a&gt;'<\/strong>\r\n<strong>    }).addTo(map);<\/strong>\r\n\r\n<strong>    L.marker([35.6812, 139.7671]).addTo(map)<\/strong>\r\n<strong>        .bindPopup('\u6771\u4eac\u99c5')<\/strong>\r\n<strong>        .openPopup();<\/strong>\r\n\r\n<strong>};<\/strong>\r\n\r\ndocument.addEventListener('livewire:initialized', () =&gt; {\r\n\r\n    \/\/ leaflet\r\n    <strong>renderLeaflet();<\/strong>\r\n\r\n});<\/pre>\n<p>\u203b <code>iconSize<\/code>\u306f\u5fc5\u305a\u30bb\u30c3\u30c8\u3057\u3066\u304f\u3060\u3055\u3044\u3002\u30ba\u30fc\u30e0\u3057\u305f\u3068\u304d\u306b\u4f4d\u7f6e\u304c\u305a\u308c\u3066\u3057\u307e\u3046\u306e\u3067\u3002<\/p>\n<\/div>\n<\/div>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-12077\" style=\"border: 3px solid #000;\" src=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_5.png\" alt=\"\" width=\"545\" height=\"566\" srcset=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_5.png 545w, https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_5-289x300.png 289w\" sizes=\"auto, (max-width: 545px) 100vw, 545px\" \/><\/p>\n<p>\u305f\u3060\u3057\u3001\u3053\u3061\u3089\u3082<code>wire:ignore<\/code>\u306f\u5fc5\u9808\u3067\u3059\u304c\u3001\u672c\u4f53\u306b\u30bb\u30c3\u30c8\u3057\u3066\u554f\u984c\u3042\u308a\u307e\u305b\u3093\u3067\u3057\u305f\u3002<\/p>\n<div>\n<pre>&lt;div id=\"map\" style=\"width:500px;height:350px;\" <strong>wire:ignore<\/strong>&gt;&lt;\/div&gt;<\/pre>\n<\/div>\n<h1>Day.js\uff08\u65e5\u4ed8\u30fb\u6642\u9593\uff09<\/h1>\n<p>\u6b21\u306b\u65e5\u4ed8\uff06\u6642\u9593\u306e\u7ba1\u7406\u3092\u3059\u308b<code>Day.js<\/code>\u3067\u3059\u3002<\/p>\n<p>\u5c11\u3057\u524d\u307e\u3067\u306f<code>moment.js<\/code>\u304c\u6709\u540d\u3067\u3057\u305f\u304c\u3001\u3059\u3067\u306b\u958b\u767a\u304c\u7d42\u4e86\u3057\u3066\u3044\u308b\u305f\u3081<code>Day.js<\/code>\u3092\u9078\u3073\u307e\u3057\u305f\u3002\uff08\u500b\u4eba\u7684\u306b\u306f<code>Luxon<\/code>\u306e\u65b9\u304c\u76f4\u611f\u7684\u3067\u597d\u304d\u3067\u3059\u304c\u3001<code>Day.js<\/code>\u306e\u65b9\u304c\u4eba\u6c17\u304c\u3042\u308b\u3063\u307d\u3044\u3067\u3059\ud83d\ude22\uff09<\/p>\n<p><strong>\uff08\u30b3\u30de\u30f3\u30c9\uff09<\/strong><\/p>\n<div>\n<pre><strong>npm install dayjs -D<\/strong><\/pre>\n<\/div>\n<p><strong>resources\/js\/bootstrap.js<\/strong><\/p>\n<div>\n<pre>\/\/ Day.js\r\n<strong>import dayjs from 'dayjs';<\/strong>\r\n<strong>import 'dayjs\/locale\/ja'; \/\/ \u65e5\u672c\u8a9e\u5316\u30d7\u30e9\u30b0\u30a4\u30f3<\/strong>\r\n<strong>dayjs.locale('ja');<\/strong>\r\n<strong>window.dayjs = dayjs;<\/strong><\/pre>\n<\/div>\n<p><strong>\uff08\u691c\u8a3c\u7d50\u679c\uff09<\/strong><\/p>\n<p>\u4ee5\u4e0b\u306e\u30b3\u30fc\u30c9\u3067<code>public $email<\/code>\u306e\u4e2d\u8eab\u3092\uff08\u3061\u3087\u3063\u3068\u304a\u304b\u3057\u3044\u3067\u3059\u304c\uff09\u65e5\u4ed8\u306b\u5165\u308c\u66ff\u3048\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3057\u305f\uff01<\/p>\n<div>\n<pre>&lt;button type=\"button\" class=\"bg-green-600 text-white px-4 py-2 rounded\"<strong> @click=\"onClick\"<\/strong>&gt;\r\n    \u30af\u30ea\u30c3\u30af\u30c6\u30b9\u30c8\r\n&lt;\/button&gt;<\/pre>\n<div>\n<pre>const onClick = () =&gt; {\r\n\r\n    <strong>@this.email = dayjs().format('YYYY\/MM\/DD\uff08ddd\uff09 HH:mm:ss');<\/strong>\r\n\r\n};<\/pre>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-12078\" style=\"border: 3px solid #000;\" src=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_6.png\" alt=\"\" width=\"271\" height=\"251\" \/><\/p>\n<p>\u3061\u306a\u307f\u306b\u3001<code>@this<\/code>\u306f\u3001\u81ea\u52d5\u7684\u306b\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u30b3\u30fc\u30c9\u306b\u5165\u308c\u66ff\u3048\u3066\u304f\u308c\u308b\u3088\u3046\u3067\u3059\ud83d\udc4d<\/p>\n<h1>Sortable\uff08\u30c9\u30e9\u30c3\u30b0\u30fb\u30a2\u30f3\u30c9\u30fb\u30c9\u30ed\u30c3\u30d7\uff09<\/h1>\n<\/div>\n<\/div>\n<p>\u76f4\u611f\u7684\u306b\u8981\u7d20\u3092\u30c9\u30e9\u30c3\u30b0\u30fb\u30a2\u30f3\u30c9\u30fb\u30c9\u30ed\u30c3\u30d7\u3057\u3066\u79fb\u52d5\u3059\u308b\u3068\u3044\u3063\u305f\u6a5f\u80fd\u3092\u7c21\u5358\u306b\u5b9f\u88c5\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u308b\u30d1\u30c3\u30b1\u30fc\u30b8\u3067\u3059\u3002<\/p>\n<p><strong>\uff08\u30b3\u30de\u30f3\u30c9\uff09<\/strong><\/p>\n<div>\n<pre><strong>npm install sortablejs -D<\/strong><\/pre>\n<\/div>\n<p><strong>resources\/js\/bootstrap.js<\/strong><\/p>\n<div>\n<pre>\/\/ Sortable\r\n<strong>import Sortable from 'sortablejs';<\/strong>\r\n<strong>window.Sortable = Sortable;<\/strong><\/pre>\n<p><strong>\uff08\u691c\u8a3c\u7d50\u679c\uff09<\/strong><\/p>\n<p>\u3053\u308c\u3082\u554f\u984c\u306a\u304f\u52d5\u304d\u307e\u3057\u305f\uff01<\/p>\n<p>\u305f\u3060\u3001\u3084\u306f\u308a<code>wire:ignore<\/code>\u304c\u306a\u3044\u3068\u518d\u30ec\u30f3\u30c0\u30ea\u30f3\u30b0\u306e\u30bf\u30a4\u30df\u30f3\u30b0\u3067\u521d\u671f\u72b6\u614b\u306b\u3082\u3069\u3063\u3066\u3057\u307e\u3046\u3088\u3046\u3067\u3057\u305f\u3002<\/p>\n<div>\n<pre><strong>&lt;ul id=\"sortable-items\" wire:ignore&gt;<\/strong>\r\n<strong>    &lt;li&gt;\u9805\u76ee\uff11&lt;\/li&gt;<\/strong>\r\n<strong>    &lt;li&gt;\u9805\u76ee\uff12&lt;\/li&gt;<\/strong>\r\n<strong>    &lt;li&gt;\u9805\u76ee\uff13&lt;\/li&gt;<\/strong>\r\n<strong>&lt;\/ul&gt;<\/strong><\/pre>\n<div>\n<pre><strong>const initSortable = () =&gt; {<\/strong>\r\n\r\n<strong>    const el = document.getElementById('sortable-items');<\/strong>\r\n<strong>    Sortable.create(el, {<\/strong>\r\n<strong>        onEnd(e) {<\/strong>\r\n\r\n<strong>            const el = e.item;<\/strong>\r\n<strong>            const oldIndex = e.oldIndex;<\/strong>\r\n<strong>            const newIndex = e.newIndex;<\/strong>\r\n<strong>            console.log(`\u300c${el.textContent}\u300d\u306e\u4f4d\u7f6e\uff1a ${oldIndex} \u2192 ${newIndex} \u3078\u79fb\u52d5`);<\/strong>\r\n\r\n<strong>        }<\/strong>\r\n<strong>    });<\/strong>\r\n\r\n<strong>};<\/strong>\r\n\r\n<strong>document.addEventListener('livewire:initialized', () =&gt; {<\/strong>\r\n\r\n<strong>    \/\/ Sortable<\/strong>\r\n<strong>    initSortable();<\/strong>\r\n\r\n<strong>});<\/strong><\/pre>\n<\/div>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-12079\" style=\"border: 3px solid #000;\" src=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_7.png\" alt=\"\" width=\"218\" height=\"277\" \/><\/p>\n<p>\u306a\u304a\u3001\u30c9\u30e9\u30c3\u30b0\u30fb\u30a2\u30f3\u30c9\u30fb\u30c9\u30ed\u30c3\u30d7\u3057\u305f\u3068\u304d\u306e\u30b3\u30f3\u30bd\u30fc\u30eb\u306f\u4ee5\u4e0b\u306e\u3068\u304a\u308a\u3067\u3059\u3002<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-12080\" style=\"border: 3px solid #000;\" src=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_8.png\" alt=\"\" width=\"274\" height=\"108\" \/><\/p>\n<h1>Lodash\uff08\u5404\u7a2e\u4fbf\u5229\u6a5f\u80fd\uff09<\/h1>\n<p>\u6b21\u306b\u3001<code>Lodash<\/code>\u3067\u3059\u304c\u3001\u3053\u308c\u306f\u3072\u3068\u3064\u306e\u6a5f\u80fd\u3067\u306f\u306a\u304f\u3044\u308d\u3044\u308d\u306a\u6a5f\u80fd\u304c\u3042\u308b\u30d1\u30c3\u30b1\u30fc\u30b8\u306b\u306a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\u4f8b\u3048\u3070\u3001\u300c<strong>\u3042\u308b\u914d\u5217\u306e\u91cd\u8907\u3092\u306a\u304f\u3059<\/strong>\u300d\u3068\u3044\u3046\u3088\u3046\u306a\u6a5f\u80fd\u3067\u3059\u3002<\/p>\n<p><strong>\uff08\u30b3\u30de\u30f3\u30c9\uff09<\/strong><\/p>\n<div>\n<pre><strong>npm install lodash -D<\/strong><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<p><strong>resources\/js\/bootstrap.js<\/strong><\/p>\n<div>\n<pre>\/\/ Lodash\r\n<strong>import _ from 'lodash';<\/strong>\r\n<strong>window._ = _;<\/strong><\/pre>\n<\/div>\n<p><strong>\uff08\u691c\u8a3c\u7d50\u679c\uff09<\/strong><\/p>\n<p><code>Lodash<\/code>\u3082\u76f4\u63a5\u898b\u3048\u308b\u90e8\u5206\u3067\u306e\u5f71\u97ff\u306f\u3042\u308a\u307e\u305b\u3093\u306e\u3067\u3001\u30af\u30ea\u30c3\u30af\u3057\u3066\u5b9f\u884c\u3067\u304d\u308b\u304b\u3092\u30c1\u30a7\u30c3\u30af\u3057\u3001\u7d50\u679c\u3046\u307e\u304f\u3044\u304d\u307e\u3057\u305f\uff01<\/p>\n<div>\n<pre><strong>const onClick = () =&gt; {<\/strong>\r\n\r\n<strong>    const numbers = [1, 2, 3, 4, 5, 1, 3, 4];<\/strong>\r\n<strong>    const uniqNumbers = _.uniq(numbers);<\/strong>\r\n\r\n<strong>    console.log(uniqNumbers);<\/strong>\r\n\r\n<strong>};<\/strong><\/pre>\n<\/div>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-12083\" style=\"border: 3px solid #000;\" src=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_9.png\" alt=\"\" width=\"242\" height=\"100\" \/><\/p>\n<h1>npm install qrcode -DSweetAlert 2<\/h1>\n<p>\u304a\u3057\u3083\u308c\u306a\u30c0\u30a4\u30a2\u30ed\u30b0\u3092\u5b9f\u88c5\u3067\u304d\u308b\u30d1\u30c3\u30b1\u30fc\u30b8\u3067\u3059\u3002<\/p>\n<p><strong>\uff08\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\uff09<\/strong><\/p>\n<div>\n<pre><strong>npm install sweetalert2 -D<\/strong><\/pre>\n<\/div>\n<p><strong>resources\/js\/bootstrap.js<\/strong><\/p>\n<div>\n<pre>\/\/ SweetAlert2\r\n<strong>import Swal from 'sweetalert2';<\/strong>\r\n<strong>window.Swal = Swal;<\/strong><\/pre>\n<\/div>\n<p><strong>\uff08\u691c\u8a3c\u7d50\u679c\uff09<\/strong><\/p>\n<p><code>SweetAlert 2<\/code>\u306f<code>wire:ignore<\/code>\u306a\u3057\u3067\u3082\u554f\u984c\u306a\u304f\u52d5\u304f\u3088\u3046\u3067\u3057\u305f\u3002<\/p>\n<div>\n<pre>const onClick = () =&gt; {\r\n\r\n<strong>    Swal.fire({<\/strong>\r\n<strong>        title: '\u30a2\u30e9\u30fc\u30c8',<\/strong>\r\n<strong>        text: '\u3046\u307e\u304f\u8868\u793a\u3067\u304d\u3066\u3044\u307e\u3059\uff01',<\/strong>\r\n<strong>        icon: 'info',<\/strong>\r\n<strong>    });<\/strong>\r\n\r\n};<\/pre>\n<\/div>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-12084\" style=\"border: 3px solid #000;\" src=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_10.png\" alt=\"\" width=\"400\" height=\"277\" srcset=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_10.png 400w, https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/10\/livewire_3_with_js_packages_10-300x208.png 300w\" sizes=\"auto, (max-width: 400px) 100vw, 400px\" \/><\/p>\n<h1>node-qrcode\uff08QR \u30b3\u30fc\u30c9\u4f5c\u6210\uff09<\/h1>\n<p>\u30d1\u30c3\u30b1\u30fc\u30b8\u540d\u306b<code>node<\/code>\u3068\u3064\u3044\u3066\u3044\u307e\u3059\u304c\u3001\u30d6\u30e9\u30a6\u30b6\u3067\u3082\u4f7f\u3048\u307e\u3059\u3002<\/p>\n<p><strong>\uff08\u30b3\u30de\u30f3\u30c9\uff09<\/strong><\/p>\n<div>\n<pre><strong>npm install qrcode -D<\/strong><\/pre>\n<\/div>\n<p><strong>resources\/js\/bootstrap.js<\/strong><\/p>\n<div>\n<pre>\/\/ node-qrcode\r\n<strong>import QRCode from 'qrcode'<\/strong>\r\n<strong>window.QRCode = QRCode;<\/strong><\/pre>\n<\/div>\n<p><strong>\uff08\u691c\u8a3c\u7d50\u679c\uff09<\/strong><\/p>\n<p>\u3053\u308c\u3082\u4ee5\u4e0b\u306e\u30b3\u30fc\u30c9\u3067\u3046\u307e\u304f\u3044\u304d\u307e\u3057\u305f\uff01<br \/>\n\u305f\u3060\u3057\u3084\u306f\u308a<code>DOM<\/code>\u306b\u5f71\u97ff\u3059\u308b\u306e\u3067\u3001<strong>wire:ignore<\/strong>\u306f\u5fc5\u8981\u3067\u3057\u305f\u3002<\/p>\n<div>\n<pre>const onClick = () =&gt; {\r\n\r\n    \/\/ node-qrcode\r\n<strong>    const canvas = document.getElementById('qrcode-canvas');<\/strong>\r\n<strong>    const text = 'https:\/\/blog.capilano-fw.com\/';<\/strong>\r\n\r\n<strong>    QRCode.toCanvas(canvas, text, function (error) {<\/strong>\r\n\r\n<strong>        if (error) console.error(error)<\/strong>\r\n<strong>        console.log('success!');<\/strong>\r\n\r\n<strong>    });<\/strong>\r\n\r\n};<\/pre>\n<div>\n<pre>&lt;canvas id=\"qrcode-canvas\" <strong>wire:ignore<\/strong>&gt;&lt;\/canvas&gt;<\/pre>\n<\/div>\n<\/div>\n<p><span id=\"install_tailwindcss\" style=\"font-size: 1.5rem;\">\u304a\u307e\u3051\uff1aTailwindCSS \u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b<\/span><\/p>\n<p>\u307e\u305a\u3001\u4ee5\u4e0b\u306e\u30b3\u30de\u30f3\u30c9\u3067<code>TailwindCSS<\/code>\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u307e\u3059\u3002<\/p>\n<div>\n<pre><strong>npm install -D tailwindcss postcss autoprefixer<\/strong><\/pre>\n<p>\u305d\u3057\u3066\u3001\u521d\u671f\u5316\u3057\u307e\u3059\u3002<\/p>\n<div>\n<pre><strong>npx tailwindcss init -p<\/strong><\/pre>\n<\/div>\n<\/div>\n<p>\u3059\u308b\u3068\u3001\u4ee5\u4e0b\uff12\u30d5\u30a1\u30a4\u30eb\u304c\u4f5c\u6210\u3055\u308c\u307e\u3059\u3002<\/p>\n<ul>\n<li>tailwind.config.js<\/li>\n<li>postcss.config.js<\/li>\n<\/ul>\n<p>\u6b21\u306b\u4f5c\u6210\u3057\u305f\u30b3\u30f3\u30d5\u30a3\u30b0\u30d5\u30a1\u30a4\u30eb\u3092\u5909\u66f4\u3057\u307e\u3059\u3002\uff08\u592a\u5b57\u90e8\u5206\u3092\u8ffd\u52a0\u3057\u307e\u3057\u305f\uff09<\/p>\n<p><strong>tailwind.config.js<\/strong><\/p>\n<div>\n<pre>\/** @type {import('tailwindcss').Config} *\/\r\nexport default {\r\n  content: [\r\n      <strong>\".\/resources\/**\/*.blade.php\",<\/strong>\r\n<strong>      \".\/resources\/**\/*.js\",<\/strong>\r\n<strong>      \".\/resources\/**\/*.vue\",<\/strong>\r\n  ],\r\n  theme: {\r\n    extend: {},\r\n  },\r\n  plugins: [],\r\n}\r\n\r\n<\/pre>\n<p>\u305d\u3057\u3066\u3001\u5404\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u305f\u3089\u3001\u4ee5\u4e0b\u306e\u30b3\u30de\u30f3\u30c9\u3067\u30d3\u30eb\u30c9\u3059\u308c\u3070<code>OK<\/code>\u3067\u3059\u3002<\/p>\n<div>\n<pre><strong>npm run build<\/strong><\/pre>\n<\/div>\n<h1>\u4f01\u696d\u69d8\u3078\u306e\u3054\u63d0\u6848<\/h1>\n<\/div>\n<p>\u4eca\u56de\u306e\u691c\u8a3c\u3067\u306f<code>Livewire 3<\/code>\u3068\u4ed6\u306e\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u4f75\u7528\u3057\u3066\u3082\u305d\u308c\u307b\u3069\u5f71\u97ff\u306f\u306a\u3044\u3053\u3068\u304c\u308f\u304b\u308a\u307e\u3057\u305f\u3002<\/p>\n<p>\u3082\u3061\u308d\u3093\u3001\u3088\u308a\u8907\u96d1\u306a\u5b9f\u88c5\u3092\u9032\u3081\u3066\u3044\u304f\u3068\u4f55\u304b\u5f71\u97ff\u304c\u51fa\u3066\u304f\u308b\u3053\u3068\u3082\u8003\u3048\u3089\u308c\u307e\u3059\u304c\u3001\u305d\u306e\u5834\u5408\u306f\u8a72\u5f53\u30da\u30fc\u30b8\u306e\u307f<code>Livewire<\/code>\u3067\u306f\u306a\u304f<code>Vue<\/code>\u3084<code>React<\/code>\u306a\u3069\u3067\u30da\u30fc\u30b8\u3092\u4f5c\u6210\u3059\u308b\u3053\u3068\u3082\u3067\u304d\u307e\u3059\u3002<\/p>\n<p>\u3082\u3057<code>Livewire<\/code>\u3092\u4f7f\u3063\u305f\u958b\u767a\u3092\u304a\u8003\u3048\u3067\u3057\u305f\u3089\u3001\u3044\u3064\u3067\u3082\u304a\u6c17\u8efd\u306b\u304a\u554f\u3044\u5408\u308f\u305b\u304f\u3060\u3055\u3044\u3002<\/p>\n<p>\u304a\u5f85\u3061\u3057\u3066\u304a\u308a\u307e\u3059\u3002\ud83d\ude0a\u2728<\/p>\n<h1>\u304a\u308f\u308a\u306b<\/h1>\n<p>\u3068\u3044\u3046\u3053\u3068\u3067\u3001\u4eca\u56de\u306f\u3044\u3064\u3082\u3068\u9055\u3063\u3066\u300c<strong>\u691c\u8a3c<\/strong>\u300d\u3092\u30e1\u30a4\u30f3\u306b\u8a18\u4e8b\u3092\u4f5c\u6210\u3057\u3066\u307f\u307e\u3057\u305f\u3002<\/p>\n<p>\u3061\u306a\u307f\u306b\u3001<code>Livewire 3<\/code>\u3068\u306e\u9023\u643a\u306f\u8a18\u4e8b\u306e\u901a\u308a\u300c<strong>\u4e88\u60f3\u3088\u308a\u4f75\u7528\u3067\u304d\u308b<\/strong>\u300d\u3088\u3046\u3067\u3057\u305f\u304c\u3001\u3061\u3087\u3063\u3068\u3060\u3051\u82e6\u52b4\u3057\u305f\u306e\u304c\u300c<strong>Vite \u3092\u4f7f\u3063\u305f\u30d3\u30eb\u30c9<\/strong>\u300d\u3067\u3059\u3002<\/p>\n<p>\u3068\u3044\u3046\u306e\u3082<code>resources\/js\/bootstrap.js<\/code>\u306b\u3069\u3046\u3084\u3063\u3066\u66f8\u304f\u304b\u306f\u305f\u307e\u306b\u30c8\u30ea\u30c3\u30ad\u30fc\u306a\u3068\u3053\u308d\u304c\u3042\u3063\u305f\u308a\u3059\u308b\uff08\u7279\u306b<code>CKEditor<\/code>\u2026\ud83d\ude2b\uff09\u306e\u3067\u3001\u5c11\u3057\u6642\u9593\u304c\u304b\u304b\u308b\u3053\u3068\u3082\u3042\u308a\u307e\u3057\u305f\u3002<\/p>\n<p>\u3068\u306f\u3044\u3048\u3001<code>Livewire 3<\/code>\u3068<code>CDN<\/code>\u3092\u5229\u7528\u3057\u305f\u30d1\u30c3\u30b1\u30fc\u30b8\u306e\u4f75\u7528\u3082\u3067\u304d\u308b\u306e\u3067\u30b7\u30f3\u30d7\u30eb\u306b\u697d\u306b\u5c0e\u5165\u3059\u308c\u3070\u958b\u767a\u3082\u5b66\u7fd2\u30b3\u30b9\u30c8\u3092\u4f4e\u304f\u3057\u305f\u307e\u307e\u306b\u3057\u3066\u304a\u3051\u308b\u3093\u3058\u3083\u306a\u3044\u3067\u3057\u3087\u3046\u304b\u3002<\/p>\n<p>\u3068\u3044\u3046\u3053\u3068\u3067\u3001\u305c\u3072\u307f\u306a\u3055\u3093\u3082<code>Livewire 3<\/code>\u30d7\u30e9\u30b9\u30a2\u30eb\u30d5\u30a1\u3067\u904a\u3093\u3067\u307f\u3066\u304f\u3060\u3055\u3044\u306d\u3002<\/p>\n<p>\u3067\u306f\u3067\u306f\u301c\u2757<\/p>\n<p style=\"text-align: center;\"><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-4328 aligncenter\" src=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2019\/08\/no_3.png\" alt=\"\" width=\"364\" height=\"320\" srcset=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2019\/08\/no_3.png 364w, https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2019\/08\/no_3-300x264.png 300w\" sizes=\"auto, (max-width: 364px) 100vw, 364px\" \/>\u300c\u6700\u8fd1\u8cb7\u3063\u305f\u30dc\u30c8\u30e0\u3001<br \/>\n\u30e2\u30b3\u30e2\u30b3\u3059\u304e\u3066<br \/>\n\u81ea\u8ee2\u8eca\u306e\u30c1\u30a7\u30fc\u30f3\u3067\u771f\u3063\u9ed2\u2026\ud83d\ude2b\u300d<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u3055\u3066\u3055\u3066\u3001\u3053\u306e\u9593 Laravel + Livewire 3 \u3067 CRUD \u3092\u5b9f\u88c5\u3057\u3066\u307f\u308b \u3068\u3044\u3046\u8a18\u4e8b\u3092\u516c\u958b\u3057\u305f\u306e\u3067\u3059\u304c\u3001\u305d\u306e\u5f8c\u3068\u3042\u308b\u3053\u3068\u304c\u6c17\u306b\u306a\u3063\u3066\u3044\u307e\u3057\u305f\u3002  &hellip; <\/p>\n<p class=\"link-more\"><a href=\"https:\/\/blog.capilano-fw.com\/?p=12064\" class=\"more-link\"><span class=\"screen-reader-text\">&#8220;livewire 3 \uff06 10\u500b\u306e\u6709\u540dJS \u30e9\u30a4\u30d6\u30e9\u30ea\u304c\u5171\u5b58\u3067\u304d\u308b\u304b\u30c1\u30a7\u30c3\u30af&#8221; \u306e<\/span>\u7d9a\u304d\u3092\u8aad\u3080<\/a><\/p>\n","protected":false},"author":1,"featured_media":12088,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[3],"tags":[168],"class_list":["post-12064","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-laravel","tag-livewire"],"_links":{"self":[{"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=\/wp\/v2\/posts\/12064","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=12064"}],"version-history":[{"count":12,"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=\/wp\/v2\/posts\/12064\/revisions"}],"predecessor-version":[{"id":12089,"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=\/wp\/v2\/posts\/12064\/revisions\/12089"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=\/wp\/v2\/media\/12088"}],"wp:attachment":[{"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=12064"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=12064"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=12064"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}