zoukankan      html  css  js  c++  java
  • 产品经理,如何面对一句话需求?

    无论需求大小、是否是一句话,只要我们能基于这句话产生疑问,通过不断设问圈定需求范围,再针对每个问题的答案给出解决方案,问题就能迎刃而解。
    —————— BEGIN ——————
    测试同学通过此篇了解需求的来源,在需求评审时候多问几个为什么
    今天的思考,源于一位同学和我分享的面试题。
    原题描述如下:
    有一个类似京东的商城在运行,该商城没有商家入驻功能,没有促销功能。
    目前计划开发促销模块,支持满赠、满减、打折,三种类型的促销,你认为开发该功能,有哪些重要的产品逻辑要考虑到,请试着梳理。
    简单说,就是让你设计三个模块:满赠、满减、打折。
    看到这个问题,我的第一反应是:这需求描述的不清楚啊……
    为什么要做这三个模块?目的是什么?要达到什么效果?具体什么场景?如何运营?等等,啥都没说,就一句话丢过来让做,这不扯么。
    后来转念一想,毕竟是面试题,这些疑问,估计面试官是想让我们自己提出来,再自己圆回来,以此判断我们的思考全面性。
    但话说来,日常工作中,确实也会经常遇到这种所谓“一句话需求”,可能老板一个点子:我们要上打折功能,就让你去开干了,留下一脸黑人问号的你,心里不断diss这不靠谱的老板。
    不过正如上面说的,这也许正是老板对你的考验。
    01
    那遇到这样的问题,应该如何思考呢?
    今天就来说说我的解决思路:
    首先要做的,就是搞清楚概念定义。
    以面试题为例,满赠、满减、打折,这三个词,太过抽象,直接去思考解决方案只会导致天马行空,没有章法。
    因此我们需要通过自问自答的方式,明确以下几个定义,把题目范围缩小:
    1)满赠
    要明确满的是什么?赠的是什么?怎么赠?三大问题。
    满的可以是钱,可以是商品数量;赠的可以是商品,可以是虚拟商品,也可以是促销特权(如优惠券,抵扣券等);赠的方式可以是下单即赠,可以是二次兑换。
    2)满减
    要明确满的是什么?减的是什么?怎么减?三大问题。
    满的可以是钱,可以是商品数量;减的可以是钱,可以是服务(比如运费);减的方式可以是付款立减,可以是买后返利。
    3)打折
    要明确怎么折的问题——是直接金钱扣减,还是基于折扣券来打。
    以上问题明确后,才能接下来给解决方案。
    02
    我们假设一种情况:
    • 满赠:满的是金钱,赠的是实体商品,赠的方式是下单即赠,也就是订单增加赠送商品,赠送商品价格为0。
    • 满减:满的是金钱,减的金钱,减的方式是下单直接减钱。
    • 打折:满的是金钱,减的是折扣金钱,减的方式是下单直接减钱。
    在此基础上,接下来要考虑的是将三种促销逻辑抽象化,讲清楚他们之间的逻辑关系。
    首先,每种促销,都是一类配置项,都要配置:触发条件,触发动作,关联实体三个参数。
    • 满赠——触发条件:满XX元。触发动作:增加N件总价为0的Y商品。关联实体:Y商品
    • 满减——触发条件:满XX元。触发动作:减YY元。关联实体:无
    • 打折——触发条件:满XX元。触发动作:乘以M折。关联实体:无。
    进一步思考,每种促销,是否都要支持多条配置项共同发挥作用;如果是,那就还要考虑支持阶梯价格。
    03
    接下来,就是要将商品SKU,和促销配置项做关联,实现具体的促销策略。
    关联时,需要考虑层级关系:
    • 一个SKU,关联一种促销的多个配置项时,应该如何处理?
    • 一个SKU,关联多种促销的一个配置项时,应该如何处理?
    • 一个SKU,关联多种促销的多个配置项时,应该如何处理?
    简单来讲,要确认是否可以逻辑叠加,叠加后有哪些限制条件。
    比如满赠后是否还可以再满减,满减了是否还能打折,打折是基于减后的钱还是减前的钱来折,打折后是否还能满减等等。
    最后,还要考虑完成促销后的售后问题:
    假设用户退货怎么退钱?这就要涉及拆单问题。
    假设用户买了后折扣力度又增大了要投诉如何给用户补差价问题。
    当然,这些特殊情况有考虑会有加分,不考虑也没太大问题,大的促销逻辑搞清楚即可。
    说到这儿,你是否心里更有数了。
    其实无论需求大小、是否是一句话,只要我们能基于这句话产生疑问,通过不断设问圈定需求范围,再针对每个问题的答案给出解决方案,问题就能迎刃而解。
     

    http://www.bcbxhome.com/bcbx/forum.php?mod=viewthread&tid=88
    (出处: 编测编学软件测试)

  • 相关阅读:
    python3 TypeError: a bytes-like object is required, not 'str'
    Centos 安装Python Scrapy PhantomJS
    Linux alias
    Vim vimrc配置
    Windows下 Python Selenium PhantomJS 抓取网页并截图
    Linux sort
    Linux RSync 搭建
    SSH隧道 访问内网机
    笔记《鸟哥的Linux私房菜》7 Linux档案与目录管理
    Tornado 错误 "Global name 'memoryview' is not defined"
  • 原文地址:https://www.cnblogs.com/zihkj/p/12431907.html
Copyright © 2011-2022 走看看