跨「产品经理与程序员」的岗位工作经验

2018-07-16  本文已影响20人  刘月玮

本文包括两个主题:

  1. 在尊重别人需求的同时,如何去理解、完善、提升需求;
  2. 在整个工作过程中间,如何保证交出来的东西是好的。

整理需求

在尊重别人需求的同时,如何去理解、完善、提升需求:

  1. 「需求」的定义:

    1. 需求不仅仅存在于产品经理的工作范畴,大多数职位的工作流程的输入都是需求,输出都是需求的阶段性成果。沟通、整理需求是大多数工作职位的必备职业技能;

      多数人会觉得都是中文讲的需求我还能听不懂吗?不就是别人说什么我们就做什么吗?如果事情这么简单,就不会有很多工作中的摩擦、也不会有做完之后说不达标来回扯皮来来回返工的事情了。真正去理解、梳理需求,是一项很重要的工作技能。

    2. 不同的工作流程中,我们既可能是需求的发起人,也可能是需求的承接者。

  2. 整理需求的步骤(泛化谈,不仅限于某个工作职位)

    1. 接受、理解需求(总)
      1. 从 what they want 到 what they need。
    2. 完善、提升需求(分)
      1. 砍需求
        1. 偶然性:去掉需求方要求的但是无益于主要功能、或者使用频次很低的需求;
        2. 性价比:去掉实现代价高、功能性或最终效果一般的需求;
        3. 伪需求:去掉实现了也没有什么实际用处的需求。
      2. 加需求
        1. 时间维度的延展:时间轴上的延伸;为未来的需求留接口。
        2. 空间维度的复用与拓展:
          1. 复用:比如不同产品、不同考试类型、不同节假日的宣传方式;
          2. 拓展:多考虑公司层面、部门层面的工作版图,工作中要抱有「拼图」的观念;
        3. 确定需求输出结果的展现形式:
          1. 讨论、细化输出格式:甚至包括字体、字号、列名、是否要标志位、标志位如何标识、word 还是 excel、颜色、图片格式等等;
          2. 原则:
            1. P0 需求发起方真正需要的;
            2. P0 最方便别人使用的;
            3. P1 在满足上两条的基础上,选择我方实现成本小的。
    3. 框架化需求(总)
      1. 建立整体的需求框架,并在层级关系上确认各个功能模块及其各自要实现的功能。
      2. 对各个功能模块进行优先级排位,排位原则是:
        1. 优先度(重要性和紧急性);
        2. 实现代价。
      3. 在初步确定需求后,可以先给需求发起方一个 demo,让需求发起方根据 demo 反馈建议,并根据建议调整需求。
  3. 整理需求的经验总结

    1. 沟通
      1. 需求交接沟通时,
        1. 常出现的问题:
          1. 需求发起人:只有一个大概的想法,未曾想过具体的内容;有太多想法,什么都想要
          2. 需求承接人:别人说什么就是什么,不问问题;问问题问不到点子上
        2. 解决方法:追问应用场景,多问 why 和 then what,问到对方也回答不出来的时候,才可能真正问到了点子上
      2. 需求变化或需求较为复杂时:
        1. 常出现的问题:时间浪费在反复沟通、来回返工上;
        2. 解决方法:不要被细节纠缠,之上而下结构化沟通问题;使用“1,2,3”的要点复述方式,彼此复述对方的观点;描述要准确准确再准确!不留任何可能扯皮的地方。
      3. 处理工作中的摩擦和情绪问题:
        1. 常出现的问题:有人挑战既定工作规范;逾期或怠工;
        2. 解决方法:
          1. 原则:解决问题最重要,同时照顾别人的情绪
          2. 方法:
            1. 如果有人在公开场合挑战既定规则,一定要求给个合理的说法,如果给不到就要根据规则严肃处理,否则正常规范的工作流程会被破坏;私底下,可以考虑个人真实情况酌情处理;
            2. 工作节点前多温柔问询,并且给点零食吃。
    2. 工作交接
      1. 需求与版本更迭时,一定要在统一的地方留存历史记录,清楚描述变更的情况和责任人;
      2. 工作流程上,向前和向后都多走一小步、多同步基础信息,保证整个工作流程是绝对畅通的。
    3. 对任何工作都要有预期
      1. 对工作估时、复杂程度有各个节点的预期,实施过程中有违背关键节点预期的内容,要及时同步给各个相关负责人;
      2. 对程序结果的预期:对异常数据更敏感;设计测试情况。

保证质量

在整个工作过程中间,保证交出来的东西是好的。严守项目流程与标准,磨刀不误砍柴工!

  1. 工作流程:
    1. 以写代码为例,代码流程:
      1. 步骤:确定需求、设计文档/流程图/ Function 设计、代码、测试;
      2. 注意:
        1. 确保上一个流程完美之后,再进行下一个环节;尽量保持环节的独立性,不让前后环节干扰当前的工作;
        2. 一定要一开始就想清楚各个模块的功能;如果代码环节有变,要优先修改设计文档;
        3. 在团队协作的每个流程内,要保证大家对整体功能、个人模块的输入和输出保持高度的同步;
        4. 异常数据常常意味着代码逻辑有问题,不可以贴补丁,一定要找到问题的根源,要从根源上解决问题。如果着急贴上了补丁,要写上备注高亮。
    2. 泛化其他工作职能:产品经理。
  2. 工作标准与规范:
    1. 以写代码为例,代码规范:
      1. 程序设计文档与代码逐逻辑块、逐行对应;
      2. team 内的代码规范要保持一致,可以在加入团队的早期,进行严格的规范说明,如有违反就发红包;
      3. 公共模块的提取,乃至模块化标准化,成为内部库函数;
      4. 严格控制输入、输出及其数据格式;每个逻辑模块内只处理该模块处理的问题;
    2. 泛化其他工作职能:UI,比如字体字号、左上紧凑对齐、区域分隔等。

关于「工作成长」的思考

  1. 初期,个人要先成为一个优秀的工具。掌握一个基本技能,交代给一个任务就能完成这个任务,保证每一个细节都经得起考验。
    1. 准确地给出别人需要的东西,展现形式要友好;
    2. 能解释出现的各类问题;
    3. 尽量提供解决方案。
  2. 随着经验积累,成为一个能制造优秀工具的人。增加创新性,想到别人想不到的问题,能科学、系统、高效地解决问题,并且能传承经验。
  3. 最后成为一个管理能制造优秀工具者的人,或者更好的制造优秀工具的人。
上一篇下一篇

猜你喜欢

热点阅读