我也无法描述清楚,直接上代码吧
根据id获取文章
/api/article/getOne?id=' + id
数据
{ "code": 200, "data": { "id": "17", "cateId": "2", "name": "视频", "studioId": "2", "title": "wegwg网服务范围", "content": "<p><b>gw3g3wg3wg</b></p><p><b>3wgf</b></p><p><b>gf3wg</b></p>", "createdAt": "2016-09-06 16:18:05" } }
获取所有文章分类
/api/category/get
数据
<code>{ "code": 200, "data": [ { "id": "1", "name": "推荐" }, { "id": "2", "name": "视频" }, { "id": "3", "name": "瘦身" }, { "id": "4", "name": "隐私" } ] }</code>
上面的接口单独调用正常,问题出现在下面。应用的场景是:载入编辑页面时,调用接口,获得数据填充到页面。
页面真实代码
//编辑文章,载入页面时,获取编辑数据并填充页面 $.ajax({ url: '/api/article/getOne?id=' + id, //获取某条文章的信息 type: 'get', dataType: 'json', beforeSend: function () { $('#show_load').show(); }, success: function (article) { console.log(article); if (article.code != 200) return false; $('#title').val(article.data.title); //文章标题 const content = htmlspecialchars_decode(article.data.content); $('#summernote').summernote('code', content); //文章内容 $.ajax({ url: '/api/category/get', //获取所有分类 type: 'get', dataType: 'json', beforeSend: function () { $('#show_load').show(); }, success: function (categorys) { console.log(categorys); //问题出现在这里,打印出来的id全部为 if (categorys.code != 200) return false; $('#categoryId').empty(); $('#categoryId').append(`<option value="0">请选择分类</option>`); categorys.data.forEach(function (v) { if(v.id = article.data.cateId){ $('#categoryId').append(`<option value="${v.id}" selected>${v.name}</option>`) }else{ $('#categoryId').append(`<option value="${v.id}">${v.name}</option>`) } }) }, complete: function () { $('#show_load').hide(); } }); }, complete: function () { $('#show_load').hide(); } });
这时打印出来的数据如下:所有分类id全部变成“1”了。原来的文章分类id也确实是“1”。但是这里全部都变成1了,到底怎么回事?
<code>{ "code": 200, "data": [ { "id": "1", "name": "推荐" }, { "id": "1", "name": "视频" }, { "id": "1", "name": "瘦身" }, { "id": "1", "name": "隐私" } ] }</code>
之前这样写是可以正常工作的。但是今天不知道为什么变成这样了。迷茫了,^$^。
回复内容:
我也无法描述清楚,直接上代码吧
根据id获取文章
/api/article/getOne?id=' + id
数据
{ "code": 200, "data": { "id": "17", "cateId": "2", "name": "视频", "studioId": "2", "title": "wegwg网服务范围", "content": "<p><b>gw3g3wg3wg</b></p><p><b>3wgf</b></p><p><b>gf3wg</b></p>", "createdAt": "2016-09-06 16:18:05" } }
获取所有文章分类
/api/category/get
数据
<code>{ "code": 200, "data": [ { "id": "1", "name": "推荐" }, { "id": "2", "name": "视频" }, { "id": "3", "name": "瘦身" }, { "id": "4", "name": "隐私" } ] }</code>
上面的接口单独调用正常,问题出现在下面。应用的场景是:载入编辑页面时,调用接口,获得数据填充到页面。
页面真实代码
//编辑文章,载入页面时,获取编辑数据并填充页面 $.ajax({ url: '/api/article/getOne?id=' + id, //获取某条文章的信息 type: 'get', dataType: 'json', beforeSend: function () { $('#show_load').show(); }, success: function (article) { console.log(article); if (article.code != 200) return false; $('#title').val(article.data.title); //文章标题 const content = htmlspecialchars_decode(article.data.content); $('#summernote').summernote('code', content); //文章内容 $.ajax({ url: '/api/category/get', //获取所有分类 type: 'get', dataType: 'json', beforeSend: function () { $('#show_load').show(); }, success: function (categorys) { console.log(categorys); //问题出现在这里,打印出来的id全部为 if (categorys.code != 200) return false; $('#categoryId').empty(); $('#categoryId').append(`<option value="0">请选择分类</option>`); categorys.data.forEach(function (v) { if(v.id = article.data.cateId){ $('#categoryId').append(`<option value="${v.id}" selected>${v.name}</option>`) }else{ $('#categoryId').append(`<option value="${v.id}">${v.name}</option>`) } }) }, complete: function () { $('#show_load').hide(); } }); }, complete: function () { $('#show_load').hide(); } });
这时打印出来的数据如下:所有分类id全部变成“1”了。原来的文章分类id也确实是“1”。但是这里全部都变成1了,到底怎么回事?
<code>{ "code": 200, "data": [ { "id": "1", "name": "推荐" }, { "id": "1", "name": "视频" }, { "id": "1", "name": "瘦身" }, { "id": "1", "name": "隐私" } ] }</code>
之前这样写是可以正常工作的。但是今天不知道为什么变成这样了。迷茫了,^$^。
/api/category/get 这个获取所有分类的链接,你重新确认下(试着直接在浏览器中直接放上这个链接,看输出的内容是否id都为1,我看一般全都是1,像这种问题基本上可以被认为是后台获取分类的代码出错...)

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

查找方法:1、用strpos(),语法“strpos("字符串值","查找子串")+1”;2、用stripos(),语法“strpos("字符串值","查找子串")+1”。因为字符串是从0开始计数的,因此两个函数获取的位置需要进行加1处理。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

禅工作室 13.0.1
功能强大的PHP集成开发环境