{"id":48901,"date":"2025-09-11T17:22:54","date_gmt":"2025-09-11T09:22:54","guid":{"rendered":"https:\/\/www.zhidianwl.com\/zhidian\/?p=48901"},"modified":"2025-09-11T17:22:54","modified_gmt":"2025-09-11T09:22:54","slug":"%e7%94%a8vue%e5%81%9a%e4%b8%80%e4%b8%aa%e9%a1%b9%e7%9b%aeapp%e8%a6%81%e6%80%8e%e4%b9%88%e5%8a%9e%ef%bc%9f","status":"publish","type":"post","link":"https:\/\/www.zhidianwl.com\/zhidian\/2025\/48901\/","title":{"rendered":"\u7528vue\u505a\u4e00\u4e2a\u9879\u76eeapp\u8981\u600e\u4e48\u529e\uff1f"},"content":{"rendered":"<p>Vue\u662f\u4e00\u6b3e\u6d41\u884c\u7684\u524d\u7aef\u6846\u67b6\uff0c\u5b83\u5177\u6709\u53cc\u5411\u6570\u636e\u7ed1\u5b9a\u3001\u7ec4\u4ef6\u5316\u3001\u6a21\u677f\u5316\u7b49\u7279\u6027\uff0c\u5728\u5f00\u53d1Web\u5e94\u7528\u65b9\u9762\u6709\u5f88\u597d\u7684\u8868\u73b0\u3002\u800cVue\u4e5f\u53ef\u4ee5\u7528\u4e8e\u6784\u5efa\u79fb\u52a8\u7aef\u7684app\u3002\u5728\u8fd9\u7bc7\u6587\u7ae0\u4e2d\uff0c\u6211\u4eec\u5c06\u8be6\u7ec6\u4ecb\u7ecd\u5982\u4f55\u4f7f\u7528Vue\u6765\u5f00\u53d1\u4e00\u4e2aapp\u3002<\/p>\n<p>1. \u73af\u5883\u642d\u5efa<\/p>\n<p>\u5728\u5f00\u59cb\u4e4b\u524d\uff0c\u6211\u4eec\u9700\u8981\u5148\u642d\u5efaVue\u5f00\u53d1\u73af\u5883\uff0c\u8fd9\u91cc\u6211\u4eec\u4f7f\u7528Vue CLI\u811a\u624b\u67b6\u5de5\u5177\u6765\u521b\u5efa\u4e00\u4e2a\u65b0\u7684Vue\u9879\u76ee\u3002\u9996\u5148\uff0c\u786e\u4fdd\u4f60\u5df2\u7ecf\u5b89\u88c5\u4e86Node.js\u548cnpm\uff0c\u63a5\u4e0b\u6765\u5728<a href=\"https:\/\/www.zhidianwl.com\/\">\u7f51\u9875\u505aapp<\/a>\u547d\u4ee4\u884c\u4e2d\u8f93\u5165\u4ee5\u4e0b\u547d\u4ee4\uff1a<\/p>\n<p>&#8220;`<\/p>\n<p>npm install -g @vue\/cli<\/p>\n<p>&#8220;`<\/p>\n<p>\u5b89\u88c5\u5b8c\u6210\u540e\uff0c\u53ef\u4ee5\u4f7f\u7528\u4ee5\u4e0b\u547d\u4ee4\u6765\u521b\u5efa\u4e00\u4e2a\u65b0\u7684Vue\u9879\u76ee\uff1a<\/p>\n<p>&#8220;`<\/p>\n<p>vue create my-app<\/p>\n<p>&#8220;`<\/p>\n<p>\u5176\u4e2d\uff0cmy-app\u662f\u9879\u76ee\u540d\u79f0\uff0c\u4f60\u53ef\u4ee5\u6839\u636e\u81ea\u5df1\u7684\u9700\u8981\u6765\u8fdb\u884c\u547d\u540d\u3002\u63a5\u4e0b\u6765\uff0c\u4f60\u9700\u8981\u6309\u7167\u63d0\u793a\u9009\u62e9\u9700\u8981\u5b89\u88c5\u7684\u529f\u80fd\u548c\u63d2\u4ef6\u7b49\u3002<\/p>\n<p>2. \u6784\u5efa\u9875\u9762<\/p>\n<p>\u5728\u9879\u76ee\u521b\u5efa\u5b8c\u6210\u540e\uff0c\u6211\u4eec\u53ef\u4ee5\u5f00\u59cb\u6784\u5efaapp\u7684\u9875\u9762\u3002\u6211\u4eec\u4ecd\u7136\u91c7\u7528Vue\u7684\u6a21\u677f\u5316\u673a<a href=\"https:\/\/www.zhidianwl.com\/\">\u667a\u7535\u745e\u521b<\/a>\u5236\u6765\u6784\u5efa\u9875\u9762\u3002Vue\u63d0\u4f9b\u4e86\u5355\u6587\u4ef6\u7ec4\u4ef6\uff08.vue\u6587\u4ef6\uff09\u7684\u529f\u80fd\uff0c\u53ef\u4ee5\u5c06HTML\u3001CSS\u3001JavaScript\u4ee3\u7801\u90fd\u5199\u5728\u4e00\u4e2a\u6587\u4ef6\u4e2d\u3002\u4f8b\u5982\uff0c\u6211\u4eec\u521b\u5efa\u4e00\u4e2a\u540d\u4e3aHome.vue\u7684\u6587\u4ef6\uff1a<\/p>\n<p>&#8220;`<\/p>\n<p>\n<p>\n<p>    {{ title }}<\/p>\n<p><p>{{ content }}<\/p>\n<\/p>\n<\/p>\n<p>export default {<\/p>\n<p>  data() {<\/p>\n<p>    return {<\/p>\n<p>      title: &#8216;\u6b22\u8fce\u6765\u5230\u6211\u7684app&#8217;,<\/p>\n<p>      content<\/p>\n<p><figure class=\"wp-block-image\"><img decoding=\"async\" src=\"https:\/\/i.yimenyun.net\/2023-04\/03\/16\/00715888836.jpg\" \/><\/figure>\n<\/p>\n<p>: &#8216;\u8fd9\u662f\u6211\u7684\u7b2c\u4e00\u4e2aVue app&#8217;<\/p>\n<p>    }<\/p>\n<p>  }<\/p>\n<p>}<\/p>\n<\/p>\n<p>h1 {<\/p>\n<p>  font-size: 24px;<\/p>\n<p>  color: red;<\/p>\n<p>}<\/p>\n<p>p {<\/p>\n<p>  font-size: 16px;<\/p>\n<p>  color: #666;<\/p>\n<p>}<\/p>\n<\/p>\n<p>&#8220;`<\/p>\n<p>\u5728\u8fd9\u4e2a\u6587\u4ef6\u4e2d\uff0c\u6211\u4eec\u5b9a\u4e49\u4e86\u4e00\u4e2atitle\u548ccontent\u53d8\u91cf\uff0c\u7528\u4e8e\u663e\u793a\u9875\u9762\u7684\u6807\u9898\u548c\u5185\u5bb9\u3002\u5728script\u5757\u4e2d\uff0c\u6211\u4eec\u4f7f\u7528Vue\u7684export default\u8bed\u6cd5\u5c06\u7ec4\u4ef6\u5bfc\u51fa\uff0c\u4ece\u800c\u53ef\u4ee5\u5728\u5176\u4ed6\u5730\u65b9\u4f7f\u7528\u3002\u5728style\u5757\u4e2d\uff0c\u6211\u4eec\u5b9a\u4e49\u4e86\u9875\u9762\u5143\u7d20\u7684\u6837\u5f0f\u3002<\/p>\n<p>3. \u8def\u7531\u914d\u7f6e<\/p>\n<p>\u5f53\u6211\u4eec\u5b9a\u4e49\u4e86\u591a\u4e2a\u9875\u9762\u65f6\uff0c\u6211\u4eec\u9700\u8981\u4e00\u79cd\u65b9\u5f0f\u6765\u7ba1\u7406\u8fd9\u4e9b\u9875\u9762\uff0c\u8fd9\u65f6\u6211\u4eec\u53ef\u4ee5\u4f7f\u7528Vue Router\u6765\u5b9e\u73b0\u8def\u7531\u3002\u5728Vue CLI\u4e2d\uff0cVue Router\u5df2\u7ecf\u5185\u7f6e\uff0c\u6211\u4eec\u53ea\u9700\u8981\u5728src\/router\/index.js\u6587\u4ef6\u4e2d\u8fdb\u884c\u8def\u7531\u7684\u914d\u7f6e\u3002<\/p>\n<p>&#8220;`<\/p>\n<p>import Vue from &#8216;vue&#8217;<\/p>\n<p>import VueRouter from &#8216;vue-router&#8217;<\/p>\n<p>import Home from &#8216;..\/views\/Home.vue&#8217;<\/p>\n<p>import About from &#8216;..\/views\/About.vue&#8217;<\/p>\n<p>Vue.use(VueRouter)<\/p>\n<p>const routes = [<\/p>\n<p>  {<\/p>\n<p>    path: &#8216;\/&#8217;,<\/p>\n<p>    name: &#8216;Home&#8217;,<\/p>\n<p>    component: Home<\/p>\n<p>  },<\/p>\n<p>  {<\/p>\n<p>    path: &#8216;\/about&#8217;,<\/p>\n<p>    name: &#8216;About&#8217;,<\/p>\n<p>    component: About<\/p>\n<p>  }<\/p>\n<p>]<\/p>\n<p>const router = new VueRouter({<\/p>\n<p>  mode: &#8216;history&#8217;,<\/p>\n<p>  base: process.env.BASE_URL,<\/p>\n<p>  routes<\/p>\n<p>})<\/p>\n<p>export default router<\/p>\n<p>&#8220;`<\/p>\n<p>\u5728\u8fd9\u4e2a\u6587\u4ef6\u4e2d\uff0c\u6211\u4eec\u9996\u5148\u5f15\u5165Vue\u3001VueRouter\u548c\u9700\u8981\u8def\u7531\u7684\u9875\u9762\u7ec4\u4ef6\uff08\u8fd9\u91cc\u6211\u4eec\u5f15\u5165\u4e86Home\u548cAbout\u7ec4\u4ef6\uff09\u3002\u63a5\u7740\uff0c\u6211\u4eec\u5b9a\u4e49\u4e86\u4e00\u4e2aroutes\u6570\u7ec4\uff0c\u7528\u4e8e\u914d\u7f6e\u8def\u7531\u8def\u5f84\u548c\u5bf9\u5e94\u7684\u7ec4\u4ef6\u3002\u6700\u540e\u901a\u8fc7new VueRouter()\u521b\u5efa\u8def\u7531\u5b9e\u4f8b\uff0c\u5e76\u5c06routes\u6570\u7ec4\u4f20\u5165\u5176\u4e2d\u3002\u6700\u7ec8\uff0c\u6211\u4eec\u9700\u8981\u5c06router\u5b9e\u4f8b\u5bfc\u51fa\uff0c\u4ece\u800c\u53ef\u4ee5\u5728\u5176\u4ed6\u5730\u65b9\u4f7f\u7528\u3002<\/p>\n<p>4. \u53d1\u9001\u8bf7\u6c42<\/p>\n<p>\u5728app\u4e2d\uff0c\u6211\u4eec\u901a\u5e38\u9700\u8981\u4ece\u540e\u7aef\u670d\u52a1\u5668\u62c9\u53d6\u6570\u636e\u3002\u5728Vue\u4e2d\uff0c\u6211\u4eec\u53ef\u4ee5\u4f7f\u7528axios\u6765\u53d1\u9001HTTP\u8bf7\u6c42\u3002\u9996\u5148\uff0c\u6211\u4eec\u9700\u8981\u5728\u9879\u76ee\u4e2d\u5b89\u88c5axios\uff1a<\/p>\n<p>&#8220;`<\/p>\n<p>npm install axios<\/p>\n<p>&#8220;`<\/p>\n<p>\u7136\u540e\uff0c\u5728\u9700\u8981\u53d1\u9001\u8bf7\u6c42\u7684\u9875\u9762\u7ec4\u4ef6\u4e2d\uff0c\u6211\u4eec\u53ef\u4ee5\u6309\u7167\u4ee5\u4e0b\u65b9\u5f0f\u8fdb\u884c\u4f7f\u7528\uff1a<\/p>\n<p>&#8220;`<\/p>\n<p>\n<p>\n<p>    {{ title }}<\/p>\n<p><p>{{ content }}<\/p>\n<\/p>\n<ul>\n<p>\n<li>{{ item.title }}<\/li>\n<\/ul>\n<\/p>\n<\/p>\n<p>import axios from &#8216;axios&#8217;<\/p>\n<p>export default {<\/p>\n<p>  data() {<\/p>\n<p>    return {<\/p>\n<p>      title: &#8216;\u6b22\u8fce\u6765\u5230\u6211\u7684app&#8217;,<\/p>\n<p>      content: &#8216;\u8fd9\u662f\u6211\u7684\u7b2c\u4e00\u4e2aVue app&#8217;,<\/p>\n<p>      items: []<\/p>\n<p>    }<\/p>\n<p>  },<\/p>\n<p>  mounted() {<\/p>\n<p>    this.fetchData()<\/p>\n<p>  },<\/p>\n<p>  methods: {<\/p>\n<p>    fetchData() {<\/p>\n<p>      axios.get(&#8216;\/api\/items&#8217;)<\/p>\n<p>        .then(response =&gt; {<\/p>\n<p>          this.items = response.data<\/p>\n<p>        })<\/p>\n<p>        .catch(error =&gt; {<\/p>\n<p>          console.log(error)<\/p>\n<p>        })<\/p>\n<p>    }<\/p>\n<p>  }<\/p>\n<p>}<\/p>\n<\/p>\n<p>h1 {<\/p>\n<p>  font-size: 24px;<\/p>\n<p>  color: red;<\/p>\n<p>}<\/p>\n<p>p {<\/p>\n<p>  font-size: 16px;<\/p>\n<p>  color: #666;<\/p>\n<p>}<\/p>\n<\/p>\n<p>&#8220;`<\/p>\n<p>\u5728\u8fd9\u4e2a\u4f8b\u5b50\u4e2d\uff0c\u6211\u4eec\u5c06items\u6570\u7ec4\u521d\u59cb\u5316\u4e3a\u7a7a\uff0c\u7136\u540e\u5728mounted\u94a9\u5b50\u51fd\u6570\u4e2d\u8c03\u7528fetchData\u65b9\u6cd5\u6765\u53d1\u9001GET\u8bf7\u6c42\u3002fetchData\u65b9\u6cd5\u4f7f\u7528axios.get()\u65b9\u6cd5\u6765\u53d1\u9001\u8bf7\u6c42\uff0c\u5e76\u5728\u8bf7\u6c42\u6210\u529f\u540e\u5c06\u54cd\u5e94\u4e2d\u7684\u6570\u636e\u8d4b\u503c\u7ed9items\u6570\u7ec4\u3002\u5982\u679c\u8bf7\u6c42\u5931\u8d25\uff0c\u6211\u4eec\u5728.catch()\u4e2d\u8f93\u51fa\u9519\u8bef\u4fe1\u606f\u3002<\/p>\n<p>5. \u6253\u5305\u53d1\u5e03<\/p>\n<p>\u6700\u540e\u4e00\u6b65\uff0c\u6211\u4eec\u9700\u8981\u5c06app\u6253\u5305\u53d1\u5e03\u5230\u751f\u4ea7\u73af\u5883\u4e2d\u3002\u5728Vue CLI\u4e2d\uff0c\u6211\u4eec\u53ef\u4ee5\u4f7f\u7528\u4ee5\u4e0b\u547d\u4ee4\u6765\u8fdb\u884c\u6253\u5305\uff1a<\/p>\n<p>&#8220;`<\/p>\n<p>npm run build<\/p>\n<p>&#8220;`<\/p>\n<p>\u8fd9\u4e2a\u547d\u4ee4\u5c06\u4f1a\u751f\u6210\u4e00\u4e2adist\u6587\u4ef6\u5939\uff0c\u91cc\u9762\u5305\u542b\u4e86\u6211\u4eec\u6253\u5305\u597d\u7684app\u4ee3\u7801\u3002\u6211\u4eec\u53ef\u4ee5\u5c06\u8fd9\u4e2a\u6587\u4ef6\u5939\u90e8\u7f72\u5230Web\u670d\u52a1\u5668\u4e0a\u8fdb\u884c\u8bbf\u95ee\u3002<\/p>\n<p>\u5230\u8fd9\u91cc\uff0c\u6211\u4eec\u5c31\u5b8c\u6210\u4e86\u4f7f\u7528Vue\u5f00\u53d1\u4e00\u4e2aapp\u7684\u6574\u4e2a\u8fc7\u7a0b\u3002\u5f53\u7136\uff0c\u8fd9\u91cc\u53ea\u6db5\u76d6\u4e86app\u5f00\u53d1\u7684\u57fa\u7840\u90e8\u5206\uff0c\u5b9e\u9645\u5f00\u53d1\u4e2d\u8fd8\u9700\u8981\u6839\u636e\u9700\u8981\u8fdb\u884c\u9002\u5f53\u7684\u529f\u80fd\u6269\u5c55\u548c\u5176\u4ed6\u4f18\u5316\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Vue\u662f\u4e00\u6b3e\u6d41\u884c\u7684\u524d\u7aef\u6846\u67b6\uff0c\u5b83\u5177\u6709\u53cc\u5411\u6570\u636e\u7ed1\u5b9a\u3001\u7ec4\u4ef6\u5316\u3001\u6a21\u677f\u5316\u7b49\u7279\u6027\uff0c\u5728\u5f00\u53d1Web\u5e94\u7528\u65b9\u9762\u6709\u5f88\u597d\u7684\u8868\u73b0\u3002\u800cVue\u4e5f\u53ef\u4ee5\u7528\u4e8e\u6784\u5efa\u79fb\u52a8\u7aef\u7684app\u3002\u5728\u8fd9\u7bc7\u6587\u7ae0\u4e2d\uff0c\u6211\u4eec\u5c06\u8be6\u7ec6\u4ecb\u7ecd\u5982\u4f55\u4f7f\u7528Vue\u6765\u5f00\u53d1\u4e00\u4e2aap<\/p>\n","protected":false},"author":14,"featured_media":0,"comment_status":"","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[38270,9384,301,4600,115],"class_list":{"0":"post-48901","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"hentry","6":"category-zuoapp","7":"tag-app","9":"tag-301","10":"tag-4600","11":"tag-115"},"_links":{"self":[{"href":"https:\/\/www.zhidianwl.com\/zhidian\/wp-json\/wp\/v2\/posts\/48901","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.zhidianwl.com\/zhidian\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.zhidianwl.com\/zhidian\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.zhidianwl.com\/zhidian\/wp-json\/wp\/v2\/users\/14"}],"replies":[{"embeddable":true,"href":"https:\/\/www.zhidianwl.com\/zhidian\/wp-json\/wp\/v2\/comments?post=48901"}],"version-history":[{"count":1,"href":"https:\/\/www.zhidianwl.com\/zhidian\/wp-json\/wp\/v2\/posts\/48901\/revisions"}],"predecessor-version":[{"id":48922,"href":"https:\/\/www.zhidianwl.com\/zhidian\/wp-json\/wp\/v2\/posts\/48901\/revisions\/48922"}],"wp:attachment":[{"href":"https:\/\/www.zhidianwl.com\/zhidian\/wp-json\/wp\/v2\/media?parent=48901"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.zhidianwl.com\/zhidian\/wp-json\/wp\/v2\/categories?post=48901"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.zhidianwl.com\/zhidian\/wp-json\/wp\/v2\/tags?post=48901"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}