Categorías
tips WebServices

10 principios de una aplicación web exitosa

Excelente charla de media hora en FOWA Miami, Fred Wilson sobre los principios que hacen exitosa a una aplicación web por sobre el resto y, pese a que más de uno va a decir “pero esto es obvio” la realidad es que muchos emprendedores que vienen del lado techie olvidan varios de los puntos.

Vale ver el video completo si te interesa y el breve resúmen traducido a la “Google Translate” está copiado y pegado acá abajo.

1. Velocidad
En primer lugar, creemos que la velocidad es más que una función. La velocidad es la característica más importante. Si su aplicación es lenta, la gente no va a usar. Veo esto más con los usuarios mainstream que con los super usuarios. Creo que los usuarios avanzados tienden a ser empáticos con los desafíos de la construcción de aplicaciones web rápidas, y quizás están dispuestos a vivir con ella, pero cuando miro a mi esposa e hijos, son mi punto de vista general de el mundo. Si algo es lento, se van!

Creemos que la aplicación tiene que ser rápida, y si no, puede ver qué pasa. Contamos con todos y cada uno de nuestros servicios de compañía de la cartera en Pingdom, y les echamos un vistazo a que todas las semanas. Cuando vemos algunas de las aplicaciones de nuestra compañía de cartera empantanarse, también notamos que no crecen tan rápidamente. Eso es evidencia empírica real que fundamente el hecho de que la velocidad es más que una función. Es un requisito.

2. Utilidad instantánea
Lo que esto significa es que el servicio sea inmediatamente útil. Si usted construye un servicio y el usuario tiene que pasar una configuración de nuestro servicio, que lo crea, la importación de contactos, haciendo un montón de entrada de datos, no creo que la gente vaya a soportarlo. El servicio tiene que ser bien útil desde la caja.

Vemos un montón de gente cometiendo este error. Hay un montón de trucos que puedes utilizar para crear la utilidad inmediata y luego salir desde allí. Un buen ejemplo de esto es si usted está construyendo un servicio de información, se puede rastrear la web para rellenar el servicio con datos iniciales, aunque a largo plazo se espera obtener los datos de otra manera. Tienes que darle a la gente algo que sea útil desde su salida.

Otro ejemplo de esto es cuando Google lanzó Google Video tal vez 4 o 5 años, casi al mismo tiempo que YouTube lanzó, si habías subido un vídeo a Google Video, después de cargado obtendría una nota que decía: “Regresa en alrededor de una semana y el vídeo se muestra.” Por supuesto, eso no funcionó muy bien. YouTube proporcionaba codificación instantánea y se podía ver el vídeo, literalmente, segundos después de que lo haya cargado. Eso es lo que estoy hablando cuando hablo acerca de la utilidad inmediata.

3. El software es un Medio
Esta es una donde tengo un montón de preguntas. Mi opinión es que el software es un medios de comunicación de hoy. En particular, software para el consumidor, cuando la usan, que se acercan a su software de la misma manera en que se enfrentarían a los medios de comunicación. Cuando digo que los medios de comunicación, estoy hablando de una revista o un periódico o un programa de televisión. Cuando piensas en el New York Times contra el Wall Street Journal, o piensa en la revista Vanity Fair en comparación con Vogue, o piensa en Fox News frente a la CNN, cada una de estas empresas de medios de comunicación tienen una voz. Tienen una actitud y un estilo, y es único. Es diferente.

Creo que el software tiene que sentirse así. Su software ha de tener una personalidad. La gente tiene que sentir que están consumiendo los medios de comunicación cuando consumen el software. Si el software es blando, y no tiene actitud, algo tan tonto como el “Fail Whale”, que se convirtió en un símbolo de la incapacidad de Twitter para mantenerse, también fue una personalidad. La gente caminaba alrededor con remeras del “Fail Whale”. Es vergonzoso para la gente de Twitter, pero sin embargo, habló del hecho de que hubo una cierta actitud y habilidad mediática detrás del servicio y una voz que la gente conectada. Eso es lo que quiero decir con voz, y yo creo que es tremendamente importante en una aplicación web.

4. Menos es Más
Y estoy convencido de ello, sobre todo al principio cuando se lanza algo. Con el tiempo, puede hacer crecer la utilidad de su servicio, y hoy en día Facebook ofrece probablemente 20 o 30 diferentes características de importancia en su servicio. Pero, cuando se puso en marcha, era realmente muy simplista. Creo que es cierto de los servicios más grandes.

Una de mis inversiones favoritas es Delicious. Lo que más me gustaba de Delicious fue su simplicidad. No había mucho que podía hacer, pero lo que podía hacer era realmente muy potente. Las personas que utilizan todos los días, horas quizá 5 o 10 por día. Los servicios, donde uno hace una cosa pequeña, pero lo hace todo el tiempo, obtiene mucha utilidad de él, y es rápido, fácil y rápido, creo que tienden a hacer muy bien y dar que en última instancia, la plataforma para crecer desde allí.

5. Hágalo programable
Hablando a un grupo de desarrolladores de aplicación web, creo que probablemente es evidente, pero creo que es importante para su aplicación ser programable, y hacer posible que otros puedan construir encima o conectarse o agregar valor a, de alguna manera , la aplicación Web. Eso significa API, y en mi opinión, API de lectura/escritura. El fundador de Delicious me dijo un par de años atrás que si no es de lectura/escritura entonces no es una API. Que se ha convertido en especie de religión dentro de nuestra empresa. Realmente creo que si es una de sólo lectura de la API, bien podría ser de RSS.

No todos los de nuestras empresas, por cierto, han lanzado API de lectura / escritura, y estamos en constante acoso a que lo hagan, pero lo importante de la programación es que cuando la gente puede agregar valor a su aplicación, son en efecto la adición de energía para tu aplicación, atraer más usuarios a su aplicación, y también trasladar datos más y más ricos para sus aplicaciones. Creemos que esto es similar a la velocidad. Esto es absolutamente esencial, y sin duda hoy, quizá no tanto 2 o 3 años atrás, pero hoy creemos muy difícil hacer una inversión en una aplicación web que no sea altamente programable.

6. Hágalo personal
Personal significa muchas cosas para muchas personas, pero en esencia, se parece mucho a la diapositiva anterior. ¿Quieres desarrolladores de terceros para infundirle energía a tu aplicación? ¿Lo mismo con los usuarios?. La mayor parte de sus datos y su personalidad y la energía que puedan contribuir a su aplicación, lo hara sentir esa aplicación como su propiedad, y los más probable es que lo defienden y se convierten, en efecto, su fuerza de comercialización. Es muy importante hacer su aplicación personal para todo el mundo. Eso podría ser permitir a las personas a cambiar sus antecedentes. Eso podría ser permitir a las personas para poner en forma de avatares, de contenido claramente generado por el usuario, o lo que sea para que la gente pueda empezar a sentirse dueño de esa aplicación web.

También es cierto que esto puede plantear problemas. Yo estaba hablando con una mujer que fue de los primeros empleados en Last.fm semana pasada, y me dijo que la comunida sentía como de su propiedad Last.fm y que estaban a cargo, y que cada vez que realiza un cambio, ellos recibe miles de mensajes en los foros. De hecho, creo que es bueno porque significa que la gente se preocupa y se preocupan profundamente por su aplicación.

Eso es cierto para un grupo de nuestras empresas, así, y es un dolor de cabeza. Cuando nuestra sociedad de cartera Meetup hizo un cambio la semana pasada a las Páginas Meetup, y hay miles de comentarios en el post anunciando que, la mayoría de ellas negativas. Usted tiene que decidir si desea o no responder a eso, o se dedican a esa o lo que sea. En gran medida, es una cosa muy buena porque la gente presta atención y muestra que han invertido tiempo y energía en su aplicación cuando se hacen personales.

7. RESTful
No sé que estoy necesariamente usar este término correctamente. Creo que la mayoría de ustedes saben que significa este término. Es algo muy concreto en un punto de vista de la arquitectura de software, pero la razón por la que ésta aquí es ligeramente diferente. Es un poco más de un mal uso de la palabra, pero voy a tratar de hacer de este sentido de todos modos.

En una arquitectura REST, los recursos tienen una dirección URL y se les puede llamar a esa URL. Ese es el tipo de arquitectura de software que se describe en el enfoque REST. ¿Qué quiero decir con esto es un poco una deformación?. Lo que quiero decir es que toda la aplicación, todo en la aplicación tiene una URL, y lo ideal, muy limpia y la URL comprensible.

Si usted piensa en algo así como una lista de Twitter, que es algo que se lanzaron cerca de 3 o 4 meses, y si vas a la página de alguien en Twitter, y hacer clic en el link de “listas”, verás una dirección URL que dice algo como “twitter.com / fredwilson / lista / …” y que serán todas las listas que estoy en. La aplicación de Twitter está construida de esa manera por lo que hay realmente nada de lo que puedes hacer clic en o mirar en la aplicación de Twitter que no tiene su propia URL, que no se entiende bien a nadie como mi mamá sabe lo que URL decir. Usted puede tomar dicha URL, enviarlo por correo electrónico, o ponerla al mundo de medios sociales.

Google podrá ver dicha URL, se descubre, y así lo que en esencia permite es que la web, en general, pueda descubrirla y acceder a su solicitud de manera muy profunda. Creo que las personas que crean aplicaciones web que no permiten que tipo muy profundo y abierto de las arquitecturas comenten un gran error. Algo tan popular como LinkedIn, por ejemplo, yo diría hace un trabajo muy pobre de este. Eso es lo que quiero decir con esto, y sé que es un poco una deformación de la palabra, pero creo que es muy importante.

8. Discoverabilty
Esto es similar en algunos aspectos, a la última diapositiva. Cuando inicia una aplicación web, es una aguja en un pajar. Hay cientos de miles, si no millones de aplicaciones web que existen en la World Wide Web, y cómo es que nadie nunca va a encontrar el tuyo? En su nivel básico, para mí, esto significa la optimización de motores de búsqueda. Usted tiene que entender la optimización de motores de búsqueda y usted tiene que entender las reglas, tienes que saber cómo hacerlo. Usted tiene que construir su aplicación desde el suelo hasta ser descubierto por Google, y optimizado para Google.

Pero, también tiene que ser construido desde cero para ser descubierto, y optimizado por los medios de comunicación social. Creo que este día y edad, los medios de comunicación social es tan importante como la búsqueda, en términos de detectabilidad en general. Eso significa que viralidad. Hay una gran entrada en el blog escrito por Josh Kopelman, que es un colega mío, fundador de la Primera Ronda de Capital. La entrada en el blog se titula algo así como “Sólo necesitamos añadir algunos viralidad”. La idea era que alguien construyó una aplicación web, nadie lo estaba usando, así que le dijo a su equipo “vamos a verter un poco de viralidad en él.” No se puede hacer eso. La solicitud tiene que ser construido desde cero para ser viral. El producto se debe presionar a sí mismo en la web, en la búsqueda, y en los medios de comunicación social. Así es como se hacen detectable.

9. Limpio
Limpieza, para mí, significa que la aplicación no puede ser ocupado en la página. Usted necesita ser capaz de mirar y no ser molestado con un montón de cosas. Es el espacio en blanco, o un espacio oscuro, que en realidad no importa si es blanco o oscuro, pero mucho espacio. Creo que fuentes de mayor tamaño, no demasiada funcionalidad presentada en cualquier página. Lo hacen muy atractivo, y hacer lo que la gente sabe, de inmediato, lo que tiene que hacer.

Lo que realmente había en esta diapositiva – cuando ésta cubierta juntos, empecé con capturas de pantalla de las aplicaciones que pensé que tenía un buen trabajo de este, y luego clase de idea decidió que no era un gran. Me mudé a sólo cosas como el jabón. Pero, lo que había aquí fue el inicio de sesión Tumblr, y cuando usted va a registrar en Tumblr, son dos campos grandes, enormes, nada más en la página de nada, sólo nombre de usuario, contraseña, y realmente me gusta lo limpio que es. Es como ninguna manera a alguien no va a saber lo que tienen que hacer ahí. Creo que es realmente crítico y la gente subestima lo valioso que es para ser eficiente con la cantidad de funcionalidad en una página.

10. Divertido
Por último pero no menos importante, es juguetón. Tenemos 6 palabras que vivimos en el Union Square Ventures. Sólo uno de ellos en realidad hizo en este mazo. El 6 palabras son: móviles, social, global, lúdico, inteligente, y me estoy olvidando de lo que el último es por lo que voy a fracasar hoy en día, pero en cualquier caso, eso es algo de lo que piensa en términos de temática aplicaciones web. Sólo uno de ellos hizo en este paquete de diapositivas, y eso es “juguetón”.

Fui criticado por poner una imagen de un patio de vacío con un charco de allí, pero hay una razón por qué lo hice. Esta diapositiva es en South Park en San Francisco. Hay una pequeña zona en la parte superior de la diapositiva donde se puede pasar el rato. Aquí es donde se inventó Twitter. Un grupo de empleados de una empresa llamada Odeo tomó un descanso en medio de un buen día, la primavera, y se fue a pensar en nuevos proyectos que pudieran construir. Un grupo fue de 4 o 5 personas que se sentaron en la parte superior de esta diapositiva y, básicamente, concebido de Twitter. Es por eso que lo usé.

En cualquier caso, la posibilidad de jugar en una aplicación es realmente importante. La dinámica de juego es lo que usted puede usar para llegar a los usuarios a hacer lo que quiera. Un ejemplo me gusta usar aquí es algo que ni siquiera es una aplicación web. Si usted piensa de Weight Watchers, es un juego. Tiene algunas dinámicas de juego realmente importante. A establecer objetivos, prepárate para enfrentarte a esos objetivos, y que informe en contra de esos objetivos, y se obtiene recompensa para alcanzar esos objetivos. Esa dinámica de juego es lo que finalmente hace que el éxito de Weight Watchers para algunas personas.

Ese tipo de enfoque se debe, de alguna manera, forma o la forma, en cada aplicación. Si nos fijamos en LinkedIn, cuando se lanzó por primera vez, tenía amigos que estaban locamente tratando de acumular relaciones en LinkedIn. Usted vio que con la gente tratando de acumular seguidores en Twitter, amigos en Facebook, y que es una especie de dinámica de juego. Es evidente que hay otro tipo de dinámica de juego que hay.

Cuadrangular sería un ejemplo de tomar elementos de juego muy parecido estado, insignias y cosas así, y utilizarlo como una manera de potenciar el desarrollo de lo que es, efectivamente, un servicio de información local. Usted no tiene que ser lo más flagrante de ello como Cuadrangular es, pero creo que las solicitudes deben ser juguetón. Hará que los usuarios tienen más divertidas con su aplicación, y porque se puede incentivar el tipo de comportamiento que desea crear en su aplicación.

Les recomiendo leer la transcripción (en inglés) de la sesión y las preguntas y respuestas en Carsonified :)

4 respuestas en “10 principios de una aplicación web exitosa”

Muy buen post. Se entiende perfecto, gracias GT :P
Tal vez no era el punto del análisis, pero hubiera estado bueno que incluya algo sobre modelo de negocios de la aplicación. Al menos un tip a tener en cuenta, para cerrar el círculo de los 10 principios. Igualmente, interesante.
Abrazo

Para mi los puntos que toda aplicación Web a de tener serían estos 10 con alguna pequeña modificación ( la 7 y la 8 no tanto si son a medida o en una apps store…)
Ciao

Los comentarios están cerrados.