解决Thinkphp与vue联合开发中Thinkphp的配置问题
2022-11-24 11:02:51
122
{{single.collect_count}}
下面由thinkphp框架教程栏目给大家介绍Thinkphp与vue联合开发中Thinkphp的配置问题,希望对需要的朋友有所帮助!

前端(vue)入门到精通课程:进入学习
Apipost = Postman + Swagger + Mock + Jmeter 超好用的API调试工具:点击使用

Thinkphp与vue联合开发中Thinkphp的配置问题:

1、Thinkphp默认返回json格式的数据

(1)全局设置 - 修改 Thinkphp 配置文件 config.php :

'default_return_type'=> 'json',
登录后复制

default_return_type 属性的默认值为'html',改成'json'后,在控制器的方法中直接return出来的数据就是json格式了,全局配置对系统中的所有“操作”有效

(2)单独设置 - 在“操作”中通过:return json(array, 404)返回数据(第一个参数是数组或对象,第二个参数是状态码)。

return json(['name' => 'thinkphp','status' => '1'], 200);
登录后复制

输出的数据(全局与单独设置输出的结果相同):

{"name":"thinkphp","status":"1"}
登录后复制

2、vue请求跨域的问题

前后端分离的情况下,vue直接通过axios请求会遇到跨域的问题:No 'Access-Control-Allow-Origin' header is present on the requested resource.

企业微信截图_15966910814958.png

需要在 “操作” 中设置请求头部

header('Access-Control-Allow-Origin: *')
登录后复制

直接复制粘贴到 “操作” 的第一行就可以了,就像这样:

企业微信截图_15966910933453.png

再通过axios连接这个“操作”时,就不会提示跨域限制了。

企业微信截图_15966911091830.png

以上就是解决Thinkphp与vue联合开发中Thinkphp的配置问题的详细内容,更多请关注php中文网其它相关文章!

回帖
全部回帖({{commentCount}})
{{item.user.nickname}} {{item.user.group_title}} {{item.friend_time}}
{{item.content}}
{{item.comment_content_show ? '取消' : '回复'}} 删除
回帖
{{reply.user.nickname}} {{reply.user.group_title}} {{reply.friend_time}}
{{reply.content}}
{{reply.comment_content_show ? '取消' : '回复'}} 删除
回帖
收起
没有更多啦~
{{commentLoading ? '加载中...' : '查看更多评论'}}