今天简单的实现了一下ecshop商品导出到第三方的购买链接功能。
大致思路是给商品添加一个buy_link的text字段,存为json结构,然后通过json解析输出到商品购买页面

1.添加字段

增加购买链接字段,执行sql语句:

1 ALTER TABLE `ecs_goods` ADD `buy_link` TEXT NULL AFTER `goods_thumb` ;

2.增加商品发布表单项

随意增加

1 <tr>
2  <td class="label">购买链接</td>
3  <td><textarea name="buy_link" cols="40" rows="3">{$goods.buy_link}</textarea></br>
4  使用了简单json结构,请严格按照格式填写(如:{'taobao':'http://','360buy':'http://'},</br>分别代表淘宝店和京东店内的购买连接)
5  </td>
6  
7  </tr>

到/admin/templates/goods_info.htm,我增加在第258行下面(即,第三个table最后注意不要破坏table结构)

后台商品编辑页面多出了一个项目

3.增加读取数据

因为涉及到数据更新,应该先给表单填写初始值。在/admin/goods.php 446行下增加

1  $smarty->assign('buy_link',$goods['buy_link']);

4.增加发布商品存库

编辑/admin/goods.php页面821开始。取得表单传值buy_link,并在insert语句中增加中字段buy_link。可以直接修改为

1 $goods_thumb = (empty($goods_thumb) && isset($_POST['auto_thumb']))? $goods_img :$goods_thumb;
2  $buy_link empty($_POST['buy_link']) ? '' : trim($_POST['buy_link']);
3  
4 /* 入库 */
5  if ($is_insert)
6  {
7  if ($code == '')
8  {
9  $sql "INSERT INTO " $ecs->table('goods') . " (goods_name, goods_name_style, goods_sn, " .
10  "cat_id, brand_id, shop_price, market_price, is_promote, promote_price, " .
11  "promote_start_date, promote_end_date, goods_img, goods_thumb, buy_link, original_img, keywords, goods_brief, " .
12  "seller_note, goods_weight, goods_number, warn_number, integral, give_integral, is_best, is_new, is_hot, " .
13  "is_on_sale, is_alone_sale, is_shipping, goods_desc, add_time, last_update, goods_type, rank_integral, suppliers_id)" .
14  "VALUES ('$_POST[goods_name]', '$goods_name_style', '$goods_sn', '$catgory_id', " .
15  "'$brand_id', '$shop_price', '$market_price', '$is_promote','$promote_price', ".
16  "'$promote_start_date', '$promote_end_date', '$goods_img', '$goods_thumb', '$buy_link', '$original_img', ".
17  "'$_POST[keywords]', '$_POST[goods_brief]', '$_POST[seller_note]', '$goods_weight', '$goods_number',".
18  " '$warn_number', '$_POST[integral]', '$give_integral', '$is_best', '$is_new', '$is_hot', '$is_on_sale', '$is_alone_sale', $is_shipping, ".
19  " '$_POST[goods_desc]', '" . gmtime() . "', '". gmtime() ."', '$goods_type', '$rank_integral', '$suppliers_id')";
20  }
21  else
22  {
23  $sql "INSERT INTO " $ecs->table('goods') . " (goods_name, goods_name_style, goods_sn, " .
24  "cat_id, brand_id, shop_price, market_price, is_promote, promote_price, " .
25  "promote_start_date, promote_end_date, goods_img, goods_thumb, buy_link, original_img, keywords, goods_brief, " .
26  "seller_note, goods_weight, goods_number, warn_number, integral, give_integral, is_best, is_new, is_hot, is_real, " .
27  "is_on_sale, is_alone_sale, is_shipping, goods_desc, add_time, last_update, goods_type, extension_code, rank_integral)" .
28  "VALUES ('$_POST[goods_name]', '$goods_name_style', '$goods_sn', '$catgory_id', " .
29  "'$brand_id', '$shop_price', '$market_price', '$is_promote','$promote_price', ".
30  "'$promote_start_date', '$promote_end_date', '$goods_img', '$goods_thumb', '$buy_link', '$original_img', ".
31  "'$_POST[keywords]', '$_POST[goods_brief]', '$_POST[seller_note]', '$goods_weight', '$goods_number',".
32  " '$warn_number', '$_POST[integral]', '$give_integral', '$is_best', '$is_new', '$is_hot', 0, '$is_on_sale', '$is_alone_sale', $is_shipping, ".
33  " '$_POST[goods_desc]', '" . gmtime() . "', '". gmtime() ."', '$goods_type', '$code', '$rank_integral')";
34  }
35  }

,这样 增加商品时就能指定buy_link了

5.增加修改商品存库

在/admin/goods.php 901 行上的sql拼接上增加

1 "buy_link = '$buy_link', " .

则变为

1 $sql .= "buy_link = '$buy_link', " .
2  "keywords = '$_POST[keywords]', " .
3  "goods_brief = '$_POST[goods_brief]', " .
4  "seller_note = '$_POST[seller_note]', " .
5  "goods_weight = '$goods_weight'," .
6  "goods_number = '$goods_number', " .
7  "warn_number = '$warn_number', " .
8  "integral = '$_POST[integral]', " .
9  "give_integral = '$give_integral', " .
10  "rank_integral = '$rank_integral', " .
11  "is_best = '$is_best', " .
12  "is_new = '$is_new', " .
13  "is_hot = '$is_hot', " .
14  "is_on_sale = '$is_on_sale', " .
15  "is_alone_sale = '$is_alone_sale', " .
16  "is_shipping = '$is_shipping', " .
17  "goods_desc = '$_POST[goods_desc]', " .
18  "last_update = '". gmtime() ."', ".
19  "goods_type = '$goods_type' " .
20  "WHERE goods_id = '$_REQUEST[goods_id]' LIMIT 1";

由此,数据入库基本完成,现在做模版赋值。

6.模版赋值

goods_info函数已经读取出来所有数据,因此直接修改/goods.php( 注:是根目录下的),在197行下增加

1 /*第三方购买链接*/
2  
3 //不是json数据则不予赋值,防止编辑格式错误致使前台js解析出错
4  
5 if(is_null(json_decode($goods['buy_link']))){
6  
7  $smarty->assign('buy_link',$goods['buy_link']);
8  
9  }

7.模版读取

修改商品详情模版,如/themes/default/goods.dwt。397行下增加

1 <!-- {* 第三方购买 *} -->
2  <!-- {if $buy_link != ""} -->
3  <script type="text/javascript" language="javascript">
4  
5 var text="";
6  
7  // if(isJSONText){
8  Jbuylink = eval("{$buy_link}");
9  for(i=0;i<Jbuylink.length;i++){
10  text +='<a href="'+Jbuylink[i].url+'"target="_blank">'+Jbuylink[i].text+'</a>&nbsp;';
11  }
12  document.write("<br/>"+text);
13  // }
14  
15  </script>
16  <!-- {/if} -->

ok,功能完成。

下面简单测试下:编辑任意商品buy_link属性为[{text:'淘宝购买',url:'http://taobao.com'},{text:'京东购买',url:'http://360buy.com?p=89899'}]         保存,查看页面,如图:

商品导出连接

由此,已经能够读取到导出链接了

第4步中的内容改为

1 <tr>
2  <td class="label">购买链接</td>
3  <td><textarea name="buy_link" cols="40" rows="3">{$goods.buy_link}</textarea></br>
4  请严格按照格式填写(如:[{text:'淘宝购买',url:'http://taobao.com'},{text:'京东购买',url:'http://360bu.com'}]  </br>分别代表淘宝店和京东店内的购买连接)
5  </td>
6  </tr>

实现Ecshop商品跳到淘宝、京东等的购买链接的更多相关文章

  1. Android跳转淘宝、京东APP商品详情页

    import Android.content.Intent; import android.content.pm.PackageManager; import android.net.Uri; imp ...

  2. 方便代理下单的EcStore收货地址一键分析插件,同时支持淘宝/京东/一号店

    使用EcStore开展分销的网站,代理需要经常代客下单,每个客户收货地址都不同,要选择和填写多个内容才能完成地址输入:省.市.区.详细地址.收货人姓名.手机电话等,非常麻烦,也容易输入错误.安装EcS ...

  3. iOS开发 仿淘宝,京东商品详情3D动画

    - (void)show { [[UIApplication sharedApplication].windows[0] addSubview:self.projectView]; CGRect fr ...

  4. AOP编程 - 淘宝京东网络处理

    现象描述 当我们打开京东 app 进入首页,如果当前是没有网络的状态,里面的按钮点击是没有反应的.只有当我们打开网络的情况下,点击按钮才能跳转页面,按照我们一般人写代码的逻辑应该是这个样子: /** ...

  5. 开源第三方登录组件OAuthLogin2.0 支持QQ,阿里巴巴,淘宝,京东,蘑菇街,有赞等平台

    Nuget地址:https://www.nuget.org/packages/OAuthLogin2.0/ 项目结构说明: AuthorizationProviders文件夹下主要存放内置的授权平台. ...

  6. 仿淘宝,京东红包雨(基于Phaser框架)

    本红包雨项目是基于HTML5的游戏框架Phaser写的,最终形成的是一个canvas,所以性能很好,但是必须要说的是这个框架比较大,压缩后也有700K左右,所以请慎用. 代码地址: https://g ...

  7. vue mint-ui 实现省市区街道4级联动(仿淘宝京东收货地址4级联动)

    demo及源码地址 https://github.com/artiely/citypicker 先去下载一个“省份.城市.区县.乡镇” 四级联动数据,然后 引入 import { Picker } f ...

  8. 解决safari里面淘宝京东页面无法打开以及打开后乱码的问题!

    sqlite3 ~/Library/Keychains/*/ocspcache.sqlite3 'DELETE FROM responses WHERE responderURI LIKE " ...

  9. js原生淘宝京东宝贝放大镜效果

    js实现商城放大镜效果 效果: 鼠标放上去会有半透明遮罩.右边会有大图片局部图. 鼠标移动时右边的大图片也会局部移动. 技术点: Event Event 是一个事件对象,当一个事件发生后,和当前事件发 ...

随机推荐

  1. javascript设计模式学习之九——命令模式

    一.命令模式使用场景及定义 命令模式常见的使用场景是:有时候需要向某些对象发送请求,但是并不知道请求的接受者是谁,也不知道请求的具体操作是什么.此时希望用一种松耦合的方式来设计程序,使得请求的发送者和 ...

  2. UIButton属性

    1.UIButton状态: UIControlStateNormal          // 正常状态    UIControlStateHighlighted     // 高亮状态    UICo ...

  3. java中的类和对象

    Java中的类是一个模板,它用于描述一类对象的行为和状态. 对象则是类中的一个实例,对象有状态(属性)和行为(方法).例如一条狗就是一个对象,他的状态就是他的颜色,名字,品种:他的行为就是叫,摇尾巴, ...

  4. 由浅到深讲解C#-LINQ

    在说LINQ之前必须先说说几个重要的C#语言特性 一:与LINQ有关的语言特性 1.隐式类型 (1)源起 在隐式类型出现之前, 我们在声明一个变量的时候, 总是要为一个变量指定他的类型 甚至在fore ...

  5. MySQL半同步复制的安装和配置

    (1)检查master/slave是否支持动态加载插件 > show variables like 'have_dynamic_loading'; +---------------------- ...

  6. mysql参数sql_log_bin

    如果想在主库上执行一些操作,但不复制到slave库上,可以通过修改参数sql_log_bin来实现. 比如想在主库上修改某个表的定义,但是在slave库上不做修改: master mysql> ...

  7. Simple GDB case

    to be added...   gdb a.out   [Inferior 1 (process 9718) exited with code 05] (gdb) list Line number ...

  8. Java基础之访问文件与目录——移动或复制文件和目录(MoveAndCopyFiles)

    控制台程序,创建和删除目录以及复制和移动文件. import java.nio.file.*; import java.nio.file.attribute.*; import java.io.IOE ...

  9. linux:指令与档案的搜索

    linux下的五种搜索方法(参考自鸟哥linux私房菜基础篇): 一.find :功能很强大,直接搜寻整个硬碟的(速度不是很快,如果系统硬碟较旧的话)----特色:find后面可以接多个目录搜索,它本 ...

  10. Git_Commands