Before I went full time building FoxyCart, I used to lead the web marketing development team (or WMD's as we liked to be called) at the Lampo Group. I was in a unique position to better understand what often trips up communication between development and marketing teams. More often than not, I was the one doing the tripping, so I learned a lot. I've shared these thoughts with my marketing and developer friends before and since Steemit has a healthy mix of both, I thought I'd share them with you as well.
So here are 5 reminders for marketers and 5 reminders for developers for keeping your teams working together smoothly:
Marketers:
- Don't let your lack of knowledge for technical details come across as not valuing your developers.
If you say things like "nerd stuff", "geek stuff" and "code magic" with a roll of the eyes or a hint of condescension, it will be picked up on and it will hurt your credibility with the development team. They may have spent years in school and countless hours researching and learning online to understand the "tech stuff" while others were out doing more socially interesting things. Respect that investment and be sure to communicate how much you value their abilities and the complexity involved.
- Don't say things like, "It's just copy/paste, right?"
80% the same can be very different than 100% the same. It can be like saying, *"Remember that Ferrari we had you build last month? We'd like to use it to transport about 40 people at once. What's that you say? A Bus? No, we can just use the Ferrari. It has wheels, an engine and a steering wheel and you already built it. That should be fine."* If you ever need a reminder of what's really going on "under the hood," have them show you a few thousands lines of code every once in a while. Just for fun, have them show you how if they mistype even one character the entire thing will no longer compile.
- Include the developers when planning out the project.
Developers are often like artists with a wide range of brush types and paints to work with. Involve them in the process, communicate what your ultimate goals are (not just your immediate ideas for reaching them) and let them work as partners, not order takers. The timelines, the budget, the objectives... those all need to include the development's point of view. For example, if you didn't schedule time for testing and remediation in the project plan, you're probably going to miss the deadline.
- Learn what is expected of you and treat it seriously.
If you're given an admin interface that is confusing or you're having trouble figuring the system out, make sure you let the developers know and ask them to help you learn it. Take notes, write procedures or ask them to make changes but no matter what, don't simply abandon it. Few things frustrate a developer more than building something and then finding out later no one is using it. In my experience, developers love helping people and solving problems. If it doesn't get used, the problem hasn't really been solved which makes them feel like their work wasn't valued. Or worse, that those making the priority decisions didn't think things through.
- Developers are usually very specific.
If you ask them to do X, Y and Z and assume they will understand that (obviously) 1, 2 and 3 are also needed to complete the project, don't be surprised if you only get the last few letters of the alphabet. Be specific. What you may see as skipping a few annoying, unimportant details a developer may see as a critical lack of planning.
In a nutshell:
Respect is the currency of knowledge-workers. Pay well.
Developers:
- Don't assume you're the only one who cares about the user (and, thus, the user experience).
Most developers like to be arm-chair marketers, but notice how few marketers try to tell you how to optimize that recursive method you've been working on? Bring your opinions and experience but keep in mind there is probably a lot to a marketing campaign that you know nothing about. There may be 20 different plates spinning all at once and, if you happen to see one crash to the floor, give the benefit of the doubt and assume the other 19 plates were more important.
- Develop a deep, genuine respect for your marketing team and communicate it often.
The marketing team's ability to promote your work pretty much pays for your salary. Don't ever assume they are ignorant or unintelligent. Chances are, they know more than you, just in different areas. For example, they probably understand people better than you. You work with code all day, they work with people all day, that's just the way it is. That means every gesture or comment you make, subconscious though it may be, communicates to them how you really feel. If you don't completely respect what they do or if you don't know how to communicate that respect, it will seriously hinder your ability to work well together.
- If you get invited to a brainstorming meeting, GO!
Yes, you'd rather be coding, but meetings are important. When invited, participate, but don't say things like "can't", "won't", or "not possible". Remember, you're the miracle worker so just about anything is possible given the right budget of time and money. It's your job to let the marketing team know what's reasonable given all the parameters. More often than not you have a solution that is not only faster and cheaper, but it also better meets the needs of the campaign. Also, don't get frustrated if they are bouncing around 10 different ideas before landing on something and needing your input, that's just how they work.
- Don't go into the details unless you have to.
Even then, have some metaphors to explain what you're talking about. I honestly suck at this, though I'm working on getting better by explaining things like Steem, blockchains, and cryptocurrencies. It's not uncommon for me to go way overboard with technical details either to stroke my own pride or to say, "see how hard that was?" Usually it's best to have the details on hand and ready, but just communicate the summary in a way that fits the audience: not too watered down so they feel patronized and not too technical so they feel stupid.
- You are employed to help generate profit or further the cause, not just write code.
It's very frustrating for a marketer to hear you missed the deadline because you rewrote the application 3 more times just because the code "didn't feel right" the first time. I'm all about refactoring when it improves performance, security or maintainability for constantly changing components, but keep in mind that even 1.0 code released to serve your customers is far better than perfect code no one ever uses.
In a nutshell:
Good marketers work their asses off. Give them a break and serve them well.
What do you think? How have you seen marketers and developers work well together and how have you seen it all fall apart? Which side (if any) are you on?
Luke Stokes
Thanks for your vote. Please follow my blog for more.