Thursday, 26 November 2015
How not to write good product descriptions
Here are some ways not to write product descriptions.
1) Focus on features - Many retailers focus on the features of a particular product. This doesn't sell your product, you should instead focus on benefits. Why do I need this 48" LCD TV? You might be tempted to write on your product page, 'Amazing 48" LCD TV, Flatscreen, 4 HDMI ports, USB and flashing lights..". Yes this is useful, but is it making me want to buy it? may be... but what if you focused on the benefits? 'Stunning 48" HD Flatscreen LCD Television, perfect for watching the FA Cup or catching up with your favourite soap'. Straight away I can see the benefits of having this TV. I can watch the football or Corrie in crystal clear Hi Def.
2) Use Manufacturers Text - Many people copy the manufacturers product descriptions directly from their site or brochure to populate their own item descriptions. Great! Now you have the same text every other person selling that product has. Not too good, I would imagine for SEO if you and 26 other retailers all have the same text word for word. Taking the time to reword standard copy lets your customers know you care about the product to make sure you know what you are selling.
3) Write for search engines - It's great to write friendly content for search engines, make sure you have keywords and important information in the descriptions, but don't over do it. Many descriptions are written with search engines in mind and although SEF or SEO'd it just doesn't read well to customers. Search engines don't buy your products, customers do, and if they can't read your description for all the bold HDMI, LCD and Samsung keywords that's not going to do anyone any good.
4) Go heavy on text - It's great writing descriptions and product information, but don't write War and Peace. Customers don't like to read! They want short, sharp sentences or even better bullet points. Sell the benefits of your product as quickly as you can to your visitors. Don't waste their time or yours with long-winded and pointless reams of text.
5) Ignore grammar and punctuation - This just doesn't look good at all. If I'm paying good money for a product online, I want to at least know the seller has taken the time to proof read what the material they are using to sell to me. If I see a product description littered with punctuation, spelling or grammar errors I lose confidence quite quickly in the whole operation.
I hope these are of some use,
Thanks,
Thursday, 20 August 2015
3 Layers of Static Code Analysis in PHP
The 3 layers can be summarised as:
- Sanity Checks
- Formal Checks
- Security Checks
Sanity and Syntax Checks
In Stage 1 we perform basically a sanity check of the code. Are there any errors, missing semi-colon's or just plain stupid things being committed to our repository and code base. This is essentially a case of running php -l against all our files being checked in or changed to make sure we catch these before they are committed and let you fix them before they are picked up by the wider team.
Formal Checks
This stage involves a more global analysis of the source code files, checking for thing such as:
- Too many or too few arguments in a function/method call
- Undeclared global or local variables
- Use of return value of a function that actually returns nothing
- Functions that have a required argument after an optional one
- Unknown functions, methods, or base classes
- Constants declared twice
Security Checks
The final layer of analysis, the security checks can be more thorough and use tools to scan our code for OWASP vulnerabilities, or as Etsy do - scan the repository with Antivirus and assess for dirty URLs.
Etsy claim they use ClamAV to check for any files or bad code which might make it's way into the repo, such as MSWord or PDF files that are suspicious. ClamAV also scans URL's and checks these against Google's Safe Browsing List to pick up on suspected Phishing or malware sites.
It is also possible to check here to ensure things like passwords aren't committed to repositories or specific naughty functions or processes are used. This can then trigger alerts for code reviews or ping back to the developer advising to fix ASAP.
Tuesday, 18 August 2015
PHP Traits
Traits allow developers to reuse sets of methods freely in several independent classes living in different class hierarchies.
Traits are a mechanism for code reuse in single inheritance languages such as PHP. A Trait is intended to reduce some limitations of single inheritance by enabling a developer to reuse sets of methods freely in several independent classes living in different class hierarchies. The semantics of the combination of Traits and classes is defined in a way which reduces complexity, and avoids the typical problems associated with multiple inheritance and Mixins.
A Trait is similar to a class, but only intended to group functionality in a fine-grained and consistent way. It is not possible to instantiate a Trait on its own. It is an addition to traditional inheritance and enables horizontal composition of behavior; that is, the application of class members without requiring inheritance.
Check out PHP.net for more info.
Saturday, 15 August 2015
Keeping Account Management REAL
The four key stages in account management are:
Recognise – The needs of the business, the customers' requirements and the role of the account manager
Evaluate – Our current customer base, prospect list, category and planning process
Act – On our plans, the sales process and required resources
Learn – From what we've done, sharpen the axe and move forward
Tuesday, 11 August 2015
How to Lose Your Clients
If you are wondering how account management could cause you to lose a client, please pay close attention. In my experience, account management is almost as important as results. Clients typically terminate accounts when they are confused or just plain frustrated with you. What are the common account management mistakes you should avoid? What are the best tips for success?
Account Management Mistakes You Should Avoid
1. Not writing a fresh email
One of the biggest mistakes I see people making is sending an email to their client with all of their internal correspondences included.
In other words, they went back and forth a few times with colleagues, and instead of writing a fresh new email, they just replied to the client from the last email they received from their colleagues.
This allows the client to see what you are saying back and forth to one another. Depending on what was said, you could really end up with your foot in your mouth.
2. Not being prepared
It's so easy to just copy and paste what someone else said to answer a client's question. The problem is, most of the time we don't really read what they wrote or get involved in the conversation.
Next thing you know, the client is calling you to talk to you and you have no idea what is going on. They might have follow up questions with regards to the multivariate test you are running.
Do you even know what they are testing or what the timeline is? You can really make a fool of yourself, and the company, if you aren't careful here.
3. Not clearly defining roles
As their account manager, the client expects to work with you and only you. It is almost pointless for you to act as account manager if you are putting them in contact with your SEO, your PPC person, your usability expert, and your analytics analyst. Now the client has to try and keep five people straight.
This will really stress the client out, and things won't get done. If there is one person they work through, they'll be more responsive and they'll be less stressed.
4. Not staying in contact
As the account manager, the client is relying on you, and only you, to stay in contact with them. You should be prepared to keep them up to date with progress reports.
Some projects won't require as much input from the client, but by providing them with regular updates they'll know that you are working hard for them.
How to Succeed as an Account Manager
The best tip? Make sure you don't make the mistakes listed above. Clients are looking for three things from you:
- Results
- Communication (with them)
- Internal communication
If you can provide them with insurance on those three things, you'll be off to a great start. My only other tip would be to never lie to a client. You'll only dig yourself in a deep hole and put yourself, your colleagues, and your company at risk. While you may not like the mistake you made, you should always fess up.
There are many ways to recover from a mistake. Lying isn't one of them.
Friday, 31 July 2015
Stop saying 'Just'
- "I just need a blog."
- "It's just a website."
- "I just need a shopping cart."
Friday, 1 May 2015
Why Estimates never work
Somewhere, right now, a project manager is compiling estimates on a software project and coming up with a completion date based on “velocity” and “scope”. When they’re done, they’ll take their completed work and show it to their boss, who will look it over, and set a “hard date” for delivering the project. There will be a team meeting, the developers will be gathered, the plan will be presented to great fanfare, and everyone will go off to work, expecting that they’ll actually meet the hard deadline in three months.
Three months will go by. The deadline will come and go. And in most cases, the deadline will be sorely missed.
You can probably guess what happens next. Executives will be furious. Project managers will blame the “lazy” developers. Developers will blame the over-zealous estimates of the project managers. There may even be a death march. At the end of it all, much if not most of the developer team will quit, the executives will vow “never again”, and the resulting project will be terrible, filled with bugs, and full of technical debt.
How do I know all this? Because I’ve seen it happen. Over and over again.
The truth is that estimates are a terrible way to determine when a project will be completed. There are four reasons why estimates fail.
Estimates are based on a best-case scenario.
When a project manager asks a developer for an estimate, they’re asking them to guess at how long something will take. The developer will use their judgement, experience, and familiarity with the project to make an estimate. But in almost all cases, these estimates are “best case scenarios”. The project manager then takes those estimates, adds them all together, and determines how long a project will take.
But what happens when the worst case comes true? I’ve worked with project managers that assume developers can do 40 hours a week of work. A sick day, a vacation, a power outage at the office or a snow storm can wreak havoc with their schedule.
Other times the developer only estimates the time needed to write the code – not to think about it. I may take 40 minutes writing a feature but spend 4 hours thinking about how it’s going to work and what it’s going to look like. If I estimate only 2/3rds of an hour, my estimate is off by 700%. Thinking time matters too.
Finally, most people are optimists. They estimate based on optimism about how long something will take. If we take that estimate as gospel, we run the risk of making a terrible mistake in our planning.
The scope estimated isn’t the scope built.
If I give you an estimate on a particular feature or task, my estimate is only good for that particular feature or task. Any changes will change the estimate. This logical, reasonable concept makes sense to most people on its face. And yet, so often it’s forgotten when we get into the nitty gritty of software work.
If a developer estimates two days for a particular task and the project manager then adds a bunch of new stuff, nobody can hold the developer to the “original estimate”. Adding stuff on will make the job take longer. Period.
“Scope creep” happens all the time. It’s common, so common that I’ve never worked on a project that didn’t have it. Yet so often the developer’s original estimate for a far smaller body of work is still used to plan the project. Is it any wonder that the final date is wrong?
Features don’t exist in a vacuum.
Features don’t exist by themselves. You don’t write a feature and have it never interact with other features. But so many estimates forget this fact. A developer will forget that a feature affecting user accounts affects every part of the application and only quote the time needed to write the new code. They forget to fix the other code that is now broken becuase of the changes.
The more massive the feature, the more impact it has on the entire system. And if an application is already built, the work is even harder. Foundational application elements are like the joists or the foundation in your house – replacing, fixing or changing the structure in a way that requires modifying these components will inevitably result in more work in unexpected areas than you otherwise anticipated.
Application development is more art than science.
To cook a steak that is one inch thick will take between 10 and 12 minutes. I know this, because I have copious amounts of experience with cooking steaks. There’s a scientific certainty that if you apply the right amount of heat for the right amount of time that you’ll get consistent results. There are many parts of cooking that are pure artistry, but there are many more that are simply chemistry.
Not so in programming. In the programming world, it’s nearly all artistry. Computer Science may be a STEM discipline in the schools, but software development is not a scientific or engineering pursuit at all.
How do we know this? Ask 100 developers to implement a function and you’ll get 100 different, unique approaches. And by “unique” I mean “completely different and novel from one another.” When it comes to many other professions, there just aren’t that many ways to do things. This is a uniqueness in the development world that’s special, but often ignored.
If you asked a famous artist, “when will that painting be done?”, you’d be told, “when it’s ready.” If you insisted on an estimate, you’d walk away with paint all over your face. And if you got an estimate and then demanded to know why the project is late, you’d be lucky to leave at all. Art doesn’t follow a schedule. Cooking a steak follows a schedule. But art does not.
But wait! What about agile/scrum/<insert development methodology here>?
There are a number of development methodologies that purport to fix the problem in a variety of ways. But they really don’t end up fixing the problem, they mask the problem by reducing the calendar time eaten by bad estimates.
Imagine that I estimate something will take 2 days. It takes twice as long, so it takes four days. If my sprint is 2 weeks long, I’ve only lost 2 days out of it. If I am consistently estimating at 1/2 the time it actually takes, I’m still delivering work on a fairly regular basis, but I’m still not estimating well.
Development methodologies were designed to reduce risk, but they don’t actually help deliver software faster. In fact, many of them come with additional overhead in providing frequent estimates, breaking up the day with stand-ups (I hate stand-ups), endless meetings and constant pressure to be right about the estimate (leading to other bad things like overtime and burn out).
So, what do we do if estimation sucks?
The answer is don’t estimate in the first place. Period. Just don’t do it.
Estimates suck. They’re rarely if ever accurate. Creating them is busy work better spent writing software instead.
So, if you don’t have estimates, how do you ship software? The answer lies in building an application that always remains stable and production-ready as new features are added, combined with the creation and implementation of small features.
The concept here shouldn’t be hard to grasp. Look at GitHub: they deploy several times a day, pushing out new features all the time. They have a solid continuous deployment process, a solid rollback process, and developers create features and ship them in a short time. Certain features are designed to be feature-flagged as off (so they don’t show up if they aren’t ready), or A/B tested.
Of course, if your app is just starting out, this can be really hard. That’s why the concept of the MVP (minimum viable product) is so important. I don’t like the MVP from a “product validation” standpoint, but I love it from a “let’s ship something quickly and iterate” standpoint.
If you’re shipping software constantly, you don’t need estimates. If a feature is taking a long time you know it, and you can work to address it by breaking it up or determining how you can declare victory sooner. Plus, your work gets shipped faster, bugs are fixed sooner, and developers are better able to move the project forward.
Estimates suck. But you don’t have to fall into the estimate trap. Instead, start shipping, start delivering, and stop driving yourself crazy with estimates that won’t be right anyway.
http://amzn.to/1JzNKyj
Steve McConnell is recognized as one of the premier authors and voices in the development community. He is Chief Software Engineer of Construx Software and was the lead developer of Construx Estimate and of SPC Estimate Professional, winner of Software Development magazine's Productivity Award. He is the author of several books, including Code Complete and Rapid Development, both honored with Software Development magazine's Jolt Award.
Check out his book
Monday, 27 April 2015
Social commerce trends in 2015
The world will be a Mobile-First World
In the big smartphone times, more and more people are put more time on mobile. In the U.S., carriers' shelf-space for devices with 4.7-inch or larger screen displays increased from 4 percent to about a third in 2014 alone, matching a sales growth - larger-screen phones now account for more than one-quarter of all sales, according to NPD Group. Facebook's recent earnings report showed that while overall daily active users grew 8 percent in 2014, mobile daily active users grew 15 percent and mobile-only daily active users grew 34 percent.
A Pay-to-Play Social World is coming
Forrester recently reported that brand interaction on organic Facebook posts is now squeezed to 0.073 percent. Social advertising spend continues to rise, though as a whole it still doesn't match time spent overall on social. Only on Facebook has spending outstripped time spent - 6 percent of U.S. adults' digital media time is spent on Facebook, but 10 percent of U.S. digital ad spending is now assigned to Facebook. But that's because for most brands, Facebook means social. And Facebook's ad products continue to improve in sophistication. As other platforms get their ad products launched, spending there will increase, too. Again, where Facebook leads, others will follow.
Social Content Continues is still rapidly developing
It's not like using content to market came out of nowhere. It's always been there. But the topic of content marketing seemed to attract an inordinate amount of attention in 2014, not only with regard to efficacy, but also about how hard it is to produce quality content in quantity. Marketers have been challenged to produce content for more channels, and have been challenged to make that content meaningful and informative. Content will continue to be a central directive for brand marketers on social.
The Development Multi Video Platform Interacting is boosted
Posting advertisements on YouTube is not sufficient to make a success now. There is increasing interaction with video in places outside YouTube, particularly with short form video on Twitter's Vine channel, as well as even shorter form GIFs on Tumblr. Surprisingly, Facebook announced that they had more video views than YouTube of this year, with many people scoffing that it was because of auto-play, not because of a video watching revolution.
The Social Diversity Will Continue
Facebook is still the biggest, most dominant social network and the "lowest common denominator" of social marketing. However, social audiences will continue splintering. This social diversity represents a serious challenge for brand marketers - particularly for brands seeking the youth market - who are looking to find the right voice for their audiences in the right location. In 2015 the social imperative will remain to hit the right voice on the right social platform, which may not be Facebook at all.
Thursday, 23 April 2015
Technical Debt
But smart employers recognise that technical debt is more than an annoyance or a cost centre. They recognise that technical debt has a chance of costing them good developers.
Developers hate technical debt. It's annoying, it's frustrating, and the struggle to find time to fix it is constant. Developers hate technical debt because it makes their jobs harder. It makes solving other problems harder. Technical debt, from a developer perspective, really sucks.
The problem here is that frustrated developers are unhappy developers. Unhappy developers have a tendency to quit. And given the fact that hiring developers is tough under the best of circumstances, this means that technical debt is actually costing your team skilled developers. And this costs money.
The loss of a single developer can cost a company £20,000 - £35,000, depending on the costs of replacing that developer. And the skills and knowledge they take with them can never really be replaced.
When considering whether or not to fix technical debt, it's worthwhile to consider the frustration level of your development team, and the cost of replacing just one of those developers if they should choose to quit. Is the cost of fixing the debt less than the cost of replacing a developer? If so, the tech debt should be paid down, until the developers are happier and satisfied.
Tuesday, 17 February 2015
Refactoring: rename class/method/variable
Monday, 9 February 2015
Legacy Code Change Algorithm
Approach
- Pick one call site.
- Change in one call site.
- Bring it under the safety net of unit tests.
- Make sure the change works.
- Meanwhile, the other call sites continue using the original unchanged code and continue to work fine.
- Go back to step 1 till all the call sites are refactored, and remove the static method finally.
Introduce Instance Delegator
- If the class which contains the static method is static, make it non static.
- Introduce an instance method with the same signature which delegates to the static method.
- Use ExtractInterface and extract the instance method created.
- At the call site for the static method, change to use the instance method (called through the extracted interface) instead of the static method.
- The instance can be provided at the call site
- as a parameter
- via setter injection
- via constructor injection
Saturday, 7 February 2015
Increase conversion rates - the easy way
In terms of an ecommerce site, be this physical goods or e-goods, for example ebooks or services, the conversion rate on your site is essentially the percentage of your visitors who you manage to convert into paying customers. People who visit your site and decide, you know what, I've just gotta have this! And if you can make them impulse buy - even better.
Here are some quick tips to increase your conversion rates:
1. Explain the benefits - 3 C's
- Clear
- Concise
- Consistent
Summarise the benefits and sell your product or services as clearly and concisely as possible. Let your customers know what they are paying their hard earned cash for, and let them know quick. Why waffle on for pages and pages? When you meet someone in person, they make their mind up about you in the first 30 seconds of the conversation. Giving someone the key benefits upfront can boost your conversion rates by as much as 150%. If you do feel the need for a more detailed description, be consistent with the key benefits you first mention so no one misses out.
2. Collect Customer Feedback
Customer feedback is key to improving your site and giving customers what they want. Services that prompt for feedback on Products and Services such as Feefo and Trustpilot are great, but what about general site experience? Services such as Qualaroo and WuFoo are great for general usability questionnaires. Ask questions such as- What information is missing from this page?
- What can we do to improve our site?
- Would your recommend our site to a friend?
3. Make your site easy to use
Another great tool for gathering feedback is iPerceptions. iPerceptions offer a free short survey to your web customers.- How would you rate your site experience?
- What describes the primary purpose of visit?
- Were you able to complete the purpose of your visit today?
4. Contact visitors that abandon
Email marketing shouldn't be underestimated in upping conversion rates, visitors who abandon during checkout, almost bought from you. Studies suggest you have a window of 90-120mins to finalise the deal or they'll go elsewhere and forget about you. A personalised email to visitors, reminding them of their shopping cart, complete with easy to follow links so they can continue where they left off should help. Let them know it's the last one in stock, or if they buy now they qualify for reduced delivery or a free pen! Everyone likes a freebie.In review.
Increasing the conversion rate on your ecommerce site needn't be all scientific with graphs and numbers. Listening to your customers and providing a personal touch will let them know you care.Thursday, 5 February 2015
Refactoring: Push down method
// bark here
}
$dog = new dog();
$dog->bark();
abstract class animal {}
class dog extends animal {
function bark(){
// bark here
}
}
class cat extends animal {}
$dog = new dog();
$dog->bark();
Tuesday, 3 February 2015
PHP Refactoring: Pull Up Method
class car extends vehicle {
Saturday, 31 January 2015
Refactoring: Replacing inheritance with delegation
}
class child extends sanitation { }
Mastering Frontend Interviews: 10 Essential Concepts Every Developer Should Know
Frontend development interviews can be daunting, particularly with the breadth of topics covered. From JavaScript fundamentals to performanc...
-
"I'm a Celebrity, Get Me Out of Here" has become a cultural phenomenon, captivating audiences worldwide with its thri...
-
The Concept of True North in Lean Methodology In the world of Lean methodology, one of the most fundamental and guiding principles is ...
-
In today's fast-paced digital landscape, ensuring the seamless operation of online services during high-demand events is paramount. The...