{"id":834,"date":"2025-06-12T00:47:24","date_gmt":"2025-06-11T16:47:24","guid":{"rendered":"https:\/\/www.zhaozhao123.cn\/php\/php-application-manual\/laravel\/834.html"},"modified":"2025-06-12T00:47:24","modified_gmt":"2025-06-11T16:47:24","slug":"%e5%a6%82%e4%bd%95%e4%bd%bf%e7%94%a8-vue-js-%e4%b8%8e-laravel","status":"publish","type":"my1js","link":"https:\/\/www.zhaozhao123.cn\/php\/my1js\/834.html","title":{"rendered":"\u5982\u4f55\u4f7f\u7528 Vue.js \u4e0e Laravel"},"content":{"rendered":"<div class=\"wp-block-columns p-0 border is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<div class=\"wp-block-columns px-4 py-3 border-bottom has-background is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\" style=\"background:linear-gradient(243deg,rgb(238,238,238) 0%,rgba(58,166,242,0.15) 100%)\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<div class=\"wp-block-group is-nowrap is-layout-flex wp-container-core-group-is-layout-6c531013 wp-block-group-is-layout-flex\">\r\n<figure class=\"wp-block-image size-thumbnail is-resized is-style-rounded is-style-rounded--1\"><img decoding=\"async\" src=\"https:\/\/www.zhaozhao123.cn\/myitems\/images\/sites16\/2025\/06\/dyA-1-400x300.jpg\" alt=\"Bug&#32534;&#35793;&#29422;\" class=\"wp-image-1842\" style=\"object-fit:cover;width:30px;height:30px\"><\/figure>\r\n\r\n\r\n\r\n<h2 class=\"wp-block-heading my-0\" style=\"font-size:clamp(0.875rem, 0.875rem + ((1vw - 0.2rem) * 0.175), 1rem);\">Bug&#32534;&#35793;&#29422;<\/h2>\r\n<\/div>\r\n<\/div>\r\n<\/div>\r\n\r\n\r\n\r\n<div class=\"wp-block-columns px-xl-5 px-4 py-xl-4 py-3 is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<p>Vue.js &#26159;&#19968;&#20010;&#27969;&#34892;&#30340;&#21069;&#31471;&#26694;&#26550;&#65292;&#32780; Laravel &#26159;&#19968;&#20010; PHP &#26694;&#26550;&#12290;&#23427;&#20204;&#21487;&#20197;&#24456;&#22909;&#22320;&#32467;&#21512;&#20351;&#29992;&#65292;&#20197;&#26500;&#24314;&#24378;&#22823;&#30340; web &#24212;&#29992;&#31243;&#24207;&#12290;&#20197;&#19979;&#26159;&#22914;&#20309;&#23558; Vue.js &#19982; Laravel &#32467;&#21512;&#20351;&#29992;&#30340;&#27493;&#39588;&#65306;<\/p>\n<h3>1. &#23433;&#35013; Laravel<\/h3>\n<p>&#39318;&#20808;&#65292;&#20320;&#38656;&#35201;&#23433;&#35013; Laravel&#12290;&#20320;&#21487;&#20197;&#36890;&#36807; Composer &#26469;&#23436;&#25104;&#36825;&#20010;&#36807;&#31243;&#12290;<\/p>\n<pre><code class=\"language-bash\">composer create-project --prefer-dist laravel\/laravel my-vue-app\ncd my-vue-app<\/code><\/pre>\n<h3>2. &#23433;&#35013; Vue CLI<\/h3>\n<p>Laravel &#25552;&#20379;&#20102;&#19968;&#20010; Vue CLI &#24037;&#20855;&#26469;&#24555;&#36895;&#21019;&#24314; Vue &#32452;&#20214;&#21644;&#39033;&#30446;&#32467;&#26500;&#12290;<\/p>\n<pre><code class=\"language-bash\">npm install -g @vue\/cli<\/code><\/pre>\n<h3>3. &#21019;&#24314; Vue &#32452;&#20214;<\/h3>\n<p>&#29616;&#22312;&#65292;&#20320;&#21487;&#20197;&#20351;&#29992; Vue CLI &#21019;&#24314;&#19968;&#20010;&#26032;&#30340; Vue &#32452;&#20214;&#12290;<\/p>\n<pre><code class=\"language-bash\">vue create src\/components\/HelloWorld.vue<\/code><\/pre>\n<p>&#36825;&#20250;&#29983;&#25104;&#19968;&#20010; <code>src\/components\/HelloWorld.vue<\/code> &#25991;&#20214;&#65292;&#24182;&#19988;&#20320;&#20250;&#30475;&#21040;&#19968;&#20123;&#40664;&#35748;&#30340;&#27169;&#26495;&#21644;&#33050;&#26412;&#25991;&#20214;&#12290;<\/p>\n<h3>4. &#22312; Laravel &#20013;&#24341;&#20837; Vue<\/h3>\n<p>&#22312; Laravel &#20013;&#65292;&#20320;&#21487;&#20197;&#36890;&#36807; CDN &#24341;&#20837; Vue &#25110;&#32773;&#20351;&#29992; npm &#21253;&#31649;&#29702;&#22120;&#26469;&#23433;&#35013; Vue&#12290;<\/p>\n<h4>&#20351;&#29992; CDN &#24341;&#20837; Vue<\/h4>\n<p>&#22312;&#20320;&#30340; HTML &#25991;&#20214;&#20013;&#24341;&#20837; Vue &#30340; CDN&#12290;<\/p>\n<pre><code class=\"language-html\">&lt;!DOCTYPE html&gt;\n&lt;html lang=\"en\"&gt;\n&lt;head&gt;\n    &lt;meta charset=\"UTF-8\"&gt;\n    &lt;meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\"&gt;\n    &lt;title&gt;Laravel with Vue&lt;\/title&gt;\n    &lt;script src=\"https:\/\/cdn.jsdelivr.net\/npm\/vue@2\"&gt;&lt;\/script&gt;\n&lt;\/head&gt;\n&lt;body&gt;\n    &lt;div id=\"app\"&gt;\n        &lt;h1&gt;{{ message }}&lt;\/h1&gt;\n    &lt;\/div&gt;\n\n    &lt;script src=\"{{ asset('js\/app.js') }}\"&gt;&lt;\/script&gt;\n&lt;\/body&gt;\n&lt;\/html&gt;<\/code><\/pre>\n<h4>&#20351;&#29992; npm &#21253;&#31649;&#29702;&#22120;&#23433;&#35013; Vue<\/h4>\n<p>&#22914;&#26524;&#20320;&#36873;&#25321;&#20351;&#29992; npm &#21253;&#31649;&#29702;&#22120;&#65292;&#21487;&#20197;&#22312; <code>package.json<\/code> &#20013;&#28155;&#21152; Vue &#20381;&#36182;&#39033;&#12290;<\/p>\n<pre><code class=\"language-json\">{\n    \"dependencies\": {\n        \"vue\": \"^2\"\n    }\n}<\/code><\/pre>\n<p>&#28982;&#21518;&#36816;&#34892; <code>npm install<\/code> &#21629;&#20196;&#26469;&#23433;&#35013;&#20381;&#36182;&#39033;&#12290;<\/p>\n<h3>5. &#22312; Laravel &#20013;&#20351;&#29992; Vue &#32452;&#20214;<\/h3>\n<p>&#22312; Laravel &#20013;&#65292;&#20320;&#21487;&#20197;&#23558; Vue &#32452;&#20214;&#27880;&#20876;&#20026;&#26381;&#21153;&#25552;&#20379;&#32773;&#65292;&#20197;&#20415;&#22312;&#24212;&#29992;&#20013;&#20840;&#23616;&#35775;&#38382;&#23427;&#12290;<\/p>\n<h4>&#27880;&#20876; Vue &#32452;&#20214;<\/h4>\n<p>&#22312; <code>AppServiceProvider.php<\/code> &#20013;&#27880;&#20876; Vue &#32452;&#20214;&#12290;<\/p>\n<pre><code class=\"language-php\">use IlluminateSupportFacadesApp;\n\nclass AppServiceProvider extends ServiceProvider\n{\n    public function boot()\n    {\n        $this-&gt;loadViewsFrom(__DIR__ . '\/..\/resources\/views', 'my-vue-app');\n\n        App::singleton('hello-world-component', function () {\n            return new MyVueAppComponentsHelloWorld();\n        });\n    }\n\n    public function register()\n    {\n        \/\/\n    }\n}<\/code><\/pre>\n<h4>&#22312;&#35270;&#22270;&#20013;&#20351;&#29992;&#32452;&#20214;<\/h4>\n<p>&#22312;&#20320;&#30340;&#35270;&#22270;&#25991;&#20214;&#20013;&#20351;&#29992;&#27880;&#20876;&#30340; Vue &#32452;&#20214;&#12290;<\/p>\n<pre><code class=\"language-blade\">&lt;!DOCTYPE html&gt;\n&lt;html lang=\"en\"&gt;\n&lt;head&gt;\n    &lt;meta charset=\"UTF-8\"&gt;\n    &lt;meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\"&gt;\n    &lt;title&gt;Laravel with Vue&lt;\/title&gt;\n    &lt;script src=\"https:\/\/cdn.jsdelivr.net\/npm\/vue@2\"&gt;&lt;\/script&gt;\n&lt;\/head&gt;\n&lt;body&gt;\n    &lt;div id=\"app\"&gt;\n        &lt;h1&gt;{{ message }}&lt;\/h1&gt;\n        &lt;hello-world-component&gt;&lt;\/hello-world-component&gt;\n    &lt;\/div&gt;\n\n    &lt;script src=\"{{ asset('js\/app.js') }}\"&gt;&lt;\/script&gt;\n&lt;\/body&gt;\n&lt;\/html&gt;<\/code><\/pre>\n<h3>6. &#36816;&#34892;&#24212;&#29992;<\/h3>\n<p>&#26368;&#21518;&#65292;&#36816;&#34892;&#20320;&#30340; Laravel &#24212;&#29992;&#12290;<\/p>\n<pre><code class=\"language-bash\">php artisan serve<\/code><\/pre>\n<p>&#29616;&#22312;&#65292;&#20320;&#24212;&#35813;&#33021;&#22815;&#30475;&#21040;&#19968;&#20010;&#24102;&#26377; Vue &#32452;&#20214;&#30340; Laravel &#24212;&#29992;&#31243;&#24207;&#12290;&#20320;&#21487;&#20197;&#26681;&#25454;&#38656;&#35201;&#36827;&#19968;&#27493;&#25193;&#23637;&#21644;&#23450;&#21046;&#36825;&#20004;&#20010;&#26694;&#26550;&#12290;<\/p>\r\n<\/div>\r\n<\/div>\r\n<\/div>\r\n<\/div><div class=\"wp-block-columns p-0 border is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<div class=\"wp-block-columns px-4 py-3 border-bottom has-background is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\" style=\"background:linear-gradient(243deg,rgb(238,238,238) 0%,rgba(58,166,242,0.15) 100%)\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<div class=\"wp-block-group is-nowrap is-layout-flex wp-container-core-group-is-layout-6c531013 wp-block-group-is-layout-flex\">\r\n<figure class=\"wp-block-image size-thumbnail is-resized is-style-rounded is-style-rounded--2\"><img decoding=\"async\" src=\"https:\/\/www.zhaozhao123.cn\/myitems\/images\/sites16\/2025\/06\/zp-400x300.jpg\" alt=\"&#40657;&#26495;Bug&#35762;&#24072;\" class=\"wp-image-1849\" style=\"object-fit:cover;width:30px;height:30px\"><\/figure>\r\n\r\n\r\n\r\n<h2 class=\"wp-block-heading my-0\" style=\"font-size:clamp(0.875rem, 0.875rem + ((1vw - 0.2rem) * 0.175), 1rem);\">&#40657;&#26495;Bug&#35762;&#24072;<\/h2>\r\n<\/div>\r\n<\/div>\r\n<\/div>\r\n\r\n\r\n\r\n<div class=\"wp-block-columns px-xl-5 px-4 py-xl-4 py-3 is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<body><h2>&#27010;&#35272;<\/h2><p>Vue.js &#21644; Laravel &#20998;&#21035;&#26159;&#29992;&#20110;&#21069;&#31471;&#21644;&#21518;&#31471;&#24320;&#21457;&#30340;&#20004;&#20010;&#24378;&#22823;&#26694;&#26550;&#12290;&#20351;&#29992;&#23427;&#20204;&#32467;&#21512;&#22312;&#19968;&#36215;&#21487;&#20197;&#23454;&#29616;&#26500;&#24314;&#21160;&#24577;&#21333;&#39029;&#24212;&#29992;&#21644;&#29992;&#25143;&#30028;&#38754;&#26102;&#26080;&#32541;&#30340;&#24320;&#21457;&#36807;&#31243;&#12290;&#26412;&#25945;&#31243;&#23558;&#25351;&#23548;&#24744;&#22914;&#20309;&#23558; Vue.js &#24341;&#20837;&#21040; Laravel &#39033;&#30446;&#20013;&#12290;<\/p><h3>&#21069;&#32622;&#26465;&#20214;<\/h3><p>&#22312;&#24320;&#22987;&#20043;&#21069;&#65292;&#35831;&#30830;&#20445;&#24050;&#23433;&#35013;&#20197;&#19979;&#36719;&#20214;&#65306;<\/p><p>Laravel &#23433;&#35013;&#22120;<\/p><p>Node.js &#21644; npm<\/p><p>PHP 7.3 &#25110;&#32773; PHP 8.0&#65292;&#20197;&#21450; Composer&#12290;<\/p><h2>&#27493;&#39588;&#24335;&#35828;&#26126;<\/h2><h3>&#27493;&#39588;1&#65306;&#21019;&#24314;&#19968;&#20010;&#26032;&#30340;Laravel&#39033;&#30446;<\/h3><p>&#39318;&#20808;&#21019;&#24314;&#19968;&#20010;&#26032;&#30340;Laravel&#39033;&#30446;&#12290;&#36816;&#34892;&#20197;&#19979;&#21629;&#20196;&#65306;<\/p><pre><code>laravel new my-vue-app<\/code><\/pre><p>&#28982;&#21518;&#65292;&#23548;&#33322;&#21040;&#20320;&#30340;&#39033;&#30446;&#30446;&#24405;&#65306;<\/p><pre><code>cd my-vue-app<\/code><\/pre><h3>&#27493;&#39588;2&#65306;&#23433;&#35013;Vue<\/h3><p>&#22312;&#20320;&#30340;Laravel&#24212;&#29992;&#20013;&#65292;&#36890;&#36807;npm&#23433;&#35013;Vue&#65306;<\/p><pre><code>npm install vue<\/code><\/pre><h3>&#27493;&#39588; 3&#65306;&#22312; Laravel &#20013;&#35774;&#32622; Vue<\/h3><p>Laravel Mix &#25552;&#20379;&#20102;&#19968;&#31181;&#31616;&#27905;&#12289;&#27969;&#30021;&#30340;API&#26469;&#23450;&#20041;&#24744;&#30340;&#24212;&#29992;&#31243;&#24207;&#30340; Webpack &#26500;&#24314;&#27493;&#39588;&#12290;&#35201;&#38598;&#25104; Vue&#65292;&#35831;&#26597;&#25214;&#24182;&#26356;&#26032; webpack.mix.js &#25991;&#20214;&#65306;<\/p><pre><code>mix.js('resources\/js\/app.js', 'public\/js').vue()<\/code><\/pre><h3>&#27493;&#39588; 4&#65306;&#21019;&#24314; Vue &#32452;&#20214;<\/h3><p>&#22909;&#30340;&#65292;&#24050;&#32463;&#23436;&#25104;&#20102;&#36825;&#20010;&#20219;&#21153;&#12290;&#29616;&#22312;&#65292;&#35831;&#38543;&#26102;&#21578;&#35785;&#25105;&#24744;&#38656;&#35201;&#25105;&#36827;&#34892;&#19979;&#19968;&#27493;&#25805;&#20316;&#12290;<\/p><pre><code>&lt;template&gt;\n  &lt;div&gt;\n    &lt;h1&gt;{{ message }}&lt;\/h1&gt;\n  &lt;\/div&gt;\n&lt;\/template&gt;\n\n&lt;script&gt;\nexport default {\n  data() {\n    return {\n      message: 'Hello Vue! Welcome to Laravel.'\n    }\n  }\n}\n&lt;\/script&gt;<\/code><\/pre><h3>&#27493;&#39588;5&#65306;&#22312;Blade&#27169;&#26495;&#20013;&#21253;&#21547;Vue&#32452;&#20214;<\/h3><p>&#22312;&#24744;&#30340;&#20027; Blade &#25991;&#20214;&#65288;&#20363;&#22914;&#65306;resources\/views\/welcome.blade.php&#65289;&#65292;&#21253;&#21547; Vue &#32452;&#20214;&#12290;<\/p><pre><code>&lt;div id=\"app\"&gt;\n  &lt;example-component&gt;&lt;\/example-component&gt;\n&lt;\/div&gt;\n\n&lt;script src=\"{{ mix('js\/app.js') }}\"&gt;&lt;\/script&gt;<\/code><\/pre><h3>&#27493;&#39588;6&#65306;&#32534;&#35793;&#36164;&#28304;<\/h3><p>&#36816;&#34892;&#20197;&#19979;&#21629;&#20196;&#32534;&#35793;&#24744;&#30340;&#36164;&#20135;&#65292;&#20854;&#20013;&#21253;&#25324;&#24744;&#30340;Vue&#32452;&#20214;&#65306;<\/p><pre><code>npm run dev<\/code><\/pre><h3>&#31532;7&#27493;&#65306;&#23433;&#35013;&#23448;&#26041;&#30340;Laravel Vue.js scaffolding<\/h3><p>&#20351;&#29992;Laravel&#65292;&#20063;&#21487;&#20197;&#21033;&#29992;&#20854;&#23448;&#26041;&#30340;Vue.js&#39592;&#26550;&#65306;<\/p><pre><code>composer require laravel\/ui\nphp artisan ui vue\nphp artisan ui vue --auth<\/code><\/pre><h2>&#32467;&#35770;&#12290;<\/h2><p>Vue.js &#21644; Laravel &#29616;&#24050;&#22312;&#24744;&#30340;&#39033;&#30446;&#20013;&#21327;&#21516;&#24037;&#20316;&#12290;&#24744;&#21019;&#24314;&#20102;&#19968;&#20010;&#26032;&#30340; Laravel &#39033;&#30446;&#65292;&#23433;&#35013;&#20102; Vue &#24182;&#28155;&#21152;&#20102;&#32452;&#20214;&#65292;&#21516;&#26102;&#23558;&#23427;&#20204;&#19982; Blade &#27169;&#26495;&#38598;&#25104;&#22312;&#19968;&#36215;&#12290;&#36825;&#31181;&#32452;&#21512;&#20351;&#24471;&#24744;&#21487;&#20197;&#26500;&#24314;&#29616;&#20195;&#12289;&#21709;&#24212;&#24335;&#30340;&#29992;&#25143;&#30028;&#38754;&#65292;&#21516;&#26102;&#21463;&#30410;&#20110; Laravel &#24378;&#22823;&#30340;&#21518;&#31471;&#21151;&#33021;&#12290;<\/p><\/body>\r\n<\/div>\r\n<\/div>\r\n<\/div>\r\n<\/div><div class=\"wp-block-columns p-0 border is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<div class=\"wp-block-columns px-4 py-3 border-bottom has-background is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\" style=\"background:linear-gradient(243deg,rgb(238,238,238) 0%,rgba(58,166,242,0.15) 100%)\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<div class=\"wp-block-group is-nowrap is-layout-flex wp-container-core-group-is-layout-6c531013 wp-block-group-is-layout-flex\">\r\n<figure class=\"wp-block-image size-thumbnail is-resized is-style-rounded is-style-rounded--3\"><img decoding=\"async\" src=\"https:\/\/www.zhaozhao123.cn\/myitems\/images\/sites16\/2025\/06\/xygcfznnzczhsdmwydzhsmzzzmddnq-400x300.jpg\" alt=\"&#38271;&#24037;&#30721;&#22900;1523\" class=\"wp-image-2906\" style=\"object-fit:cover;width:30px;height:30px\"><\/figure>\r\n\r\n\r\n\r\n<h2 class=\"wp-block-heading my-0\" style=\"font-size:clamp(0.875rem, 0.875rem + ((1vw - 0.2rem) * 0.175), 1rem);\">&#38271;&#24037;&#30721;&#22900;1523<\/h2>\r\n<\/div>\r\n<\/div>\r\n<\/div>\r\n\r\n\r\n\r\n<div class=\"wp-block-columns px-xl-5 px-4 py-xl-4 py-3 is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<p>Vue.js &#21644; Laravel &#26159;&#20004;&#20010;&#38750;&#24120;&#27969;&#34892;&#30340;&#21069;&#31471;&#26694;&#26550;&#21644;&#21518;&#31471;&#26694;&#26550;&#65292;&#23427;&#20204;&#32467;&#21512;&#21487;&#20197;&#26500;&#24314;&#20986;&#24378;&#22823;&#30340;&#20840;&#26632;&#24212;&#29992;&#12290;<\/p>\n<h3>&#22914;&#20309;&#20351;&#29992; Vue.js &#19982; Laravel<\/h3>\n<ol>\n<li>\n<p>&#23433;&#35013; Laravel<\/p>\n<ul>\n<li>&#20351;&#29992; Composer &#23433;&#35013; Laravel: <code>composer require laravel\/laravel<\/code><\/li>\n<\/ul>\n<\/li>\n<li>\n<p>&#21019;&#24314;&#19968;&#20010;&#26032;&#30340; Laravel &#24212;&#29992;<\/p>\n<pre><code class=\"language-bash\">composer create-project --prefer-dist laravel\/laravel your-project-name<\/code><\/pre>\n<p>&#36825;&#23558;&#21019;&#24314;&#19968;&#20010;&#21517;&#20026; <code>your-project-name<\/code> &#30340;&#26032;&#39033;&#30446;&#65292;&#24182;&#23433;&#35013;&#20102; Laravel &#20197;&#21450;&#20854;&#20182;&#20381;&#36182;&#21253;&#12290;<\/p>\n<\/li>\n<li>\n<p>&#21021;&#22987;&#21270; Laravel &#27169;&#22411;<\/p>\n<pre><code class=\"language-php\">php artisan make:model MyModel<\/code><\/pre>\n<\/li>\n<li>\n<p>&#35774;&#32622;&#36335;&#30001;&#21644;&#25511;&#21046;&#22120;<\/p>\n<pre><code class=\"language-php\">\/\/ app\/Http\/Controllers\/HomeController.php\nnamespace AppHttpControllers;\n\nuse IlluminateHttpRequest;\n\nclass HomeController extends Controller\n{\n   public function index()\n   {\n       return view('welcome');\n   }\n}\n\n\/\/ routes\/web.php\nRoute::get('\/', 'HomeController@index')-&gt;name('home');<\/code><\/pre>\n<\/li>\n<li>\n<p>&#37197;&#32622;&#25968;&#25454;&#24211;&#36801;&#31227;<\/p>\n<pre><code class=\"language-php\">php artisan migrate<\/code><\/pre>\n<\/li>\n<li>\n<p>&#21019;&#24314; Vue &#32452;&#20214;<\/p>\n<pre><code class=\"language-html\">&lt;template&gt;\n &lt;div&gt;\n   &lt;h1&gt;{{ name }}&lt;\/h1&gt;\n   &lt;button @click=\"increment\"&gt;Increment&lt;\/button&gt;\n &lt;\/div&gt;\n&lt;\/template&gt;\n\n&lt;script&gt;\nexport default {\n data() {\n   return {\n     name: 'World',\n   };\n },\n methods: {\n   increment() {\n     this.name = `${this.name}++`;\n   },\n },\n};\n&lt;\/script&gt;<\/code><\/pre>\n<\/li>\n<li>\n<p>&#22312; Laravel &#20013;&#20351;&#29992; Vue &#32452;&#20214;<\/p>\n<pre><code class=\"language-php\">\n&lt;!-- resources\/views\/layouts\/app.blade.php --&gt;\n&lt;link href=\"{{ asset('css\/app.css') }}\" rel=\"stylesheet\"&gt;\n&lt;script src=\"{{ asset('js\/app.js') }}\"&gt;&lt;\/script&gt;\n\n&lt;!-- components\/VueComponent.vue --&gt;\n&lt;template&gt;\n &lt;div&gt;\n   {{ message }}\n &lt;\/div&gt;\n&lt;\/template&gt;\n\n&lt;script&gt;\nimport axios from 'axios';\n\nexport default {\n props: ['message'],\n data() {\n   return {\n     loading: false,\n     error: null,\n   };\n },\n mounted() {\n   this.fetchData();\n },\n methods: {\n   fetchData() {\n     this.loading = true;<\/code><\/pre>\n<\/li>\n<\/ol>\n<p>Comment: This line is not needed as the template already has a closing tag for it. suggestion <\/p>\r\n<\/div>\r\n<\/div>\r\n<\/div>\r\n<\/div>\n","protected":false},"excerpt":{"rendered":"<p>Bug&#32534;&#35793;&#29422; Vue.js &#26159;&#19968;&#20010;&#27969;&#34892;&#30340;&#21069;&#31471;&#26694;&#26550;&#65292;&#32780; Laravel &#26159;&#19968;&#038;#20..<\/p>\n","protected":false},"author":1,"featured_media":0,"menu_order":0,"template":"","meta":{"_acf_changed":false},"tags":[],"my1js2nav":[44],"tuisongtax":[],"class_list":["post-834","my1js","type-my1js","status-publish","hentry","my1js2nav-laravel"],"acf":{"qian_art_seotitle":"","qian_art_seotitle_source":{"label":"SEO\u6807\u9898","type":"text","formatted_value":""},"qian_art_seokws":"","qian_art_seokws_source":{"label":"SEO\u5173\u952e\u8bcd","type":"text","formatted_value":""},"qian_art_stzhong":"","qian_art_stzhong_source":{"label":"\u4e2d | \u77ed\u6807\u9898","type":"text","formatted_value":""}},"_links":{"self":[{"href":"https:\/\/www.zhaozhao123.cn\/php\/wp-json\/wp\/v2\/my1js\/834","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.zhaozhao123.cn\/php\/wp-json\/wp\/v2\/my1js"}],"about":[{"href":"https:\/\/www.zhaozhao123.cn\/php\/wp-json\/wp\/v2\/types\/my1js"}],"author":[{"embeddable":true,"href":"https:\/\/www.zhaozhao123.cn\/php\/wp-json\/wp\/v2\/users\/1"}],"wp:attachment":[{"href":"https:\/\/www.zhaozhao123.cn\/php\/wp-json\/wp\/v2\/media?parent=834"}],"wp:term":[{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.zhaozhao123.cn\/php\/wp-json\/wp\/v2\/tags?post=834"},{"taxonomy":"my1js2nav","embeddable":true,"href":"https:\/\/www.zhaozhao123.cn\/php\/wp-json\/wp\/v2\/my1js2nav?post=834"},{"taxonomy":"tuisongtax","embeddable":true,"href":"https:\/\/www.zhaozhao123.cn\/php\/wp-json\/wp\/v2\/tuisongtax?post=834"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}