- 浏览: 59640 次
- 性别:
- 来自: 北京
最新评论
-
luogen33:
...
System -
sunzhyng:
好的,有时间看看哎,这个帖子竟然成了新手帖,扣10个积分。我是 ...
java使用类似ini文件IniProperties的类 -
sutra:
这个呢? http://sourceforge.net/pro ...
找出汉字的拼音,既有各汉字的首字母和所有汉字的全拼
iCalendar URLs for date-related data
If your application’s data is date-related, then make the data available in iCalendar format, to allow people to view the data in calendaring software. For example, a time sheet application could display time spent on a calendar, as illustrated in iCalendar feeds using iCal4J .
This is an example of letting people use dedicated desktop applications to view data in a dedicated user-interface, instead of recreating that user-interface in your web application.
For example, iCal , which can subscribe to an iCalendar feed, has a better calendar user-interface than the average on-line calendar. Google Calendar , meanwhile, provides a public or private ‘calendar address’ that allows you to view calendars in an iCalendar client such as iCal.
KML URLs for geographic data
In the same way that iCal has a better calendar user-interface, Google Earth has a better geographical user-interface. If you have geographic data, generate dynamic KML documents that people can use to view the data in Google Earth or on a map.
For example, a Tagzania category has a KML icon that provides the same data via KML.
Export data to a file
If your data is not a good fit for an XML format for which there are dedicated applications, such as RSS, OpenSearch and KML, then invent your own XML mark-up and export your data in that format. You probably need to do this anyway, to be able to include all of your application’s data.
This makes all sorts of applications possible, not least because you can transform this XML into any other kind using XSLT . This is also the sort of feature that gives people a warm fuzzy feeling because it protects them from data lock-in and allows them to make their own back-ups.
Import data from a file
Once you have functionality to export your data to a file, allow the user to Restore database from back-up by uploading a previously-exported file.
This makes it easy to move data between accounts or servers, and makes the XML back-up files more useful.
Collaboration features
Although collaboration is the killer application category for the web, many web applications simply implement the functionality of single-user desktop applications and fail to support business activities that involve multiple people. That is to say, all of them.
Comments
Allow logged-in users to post comments on pages that display the application’s key data. Comments do not need to be threaded, but should include the user’s name and the date and time posted. Allow the author of a comment to delete it. Optionally, make comments editable for their authors, and for advanced users, support rich-text mark-up such as one of the many wiki syntaxes. You do not need comments on every kind of data, just the most significant entity. For example, in Amazon you can comment on books and other products, but not on authors or publishers.
Comments are simple to implement, but can quickly deliver value in more than one way. Initially, comments are a useful way to let users annotate application data with unstructured data that would otherwise be lost, or not made available for other users. Beyond that, comments allow conversations about the data that are displayed in context. These conversations can be much more valuable and accessible when centred around the data like this, with ad-hoc participants, rather than centred around a particular group of people.
A series of comments about a software bug in a bug tracker like JIRA is always in the context of a particular bug, unlike conversation in a discussion forum. Even worse is e-mail, where people who arrive late to the conversation miss the beginning. For examples, comments in Lunatech’s JIRA on a bug that would be fixed by an upgrade - the bug is the context:
Tags
Allow users to add simple tags to data in your application, and delete them again. Then add tag-based data browsing - click a tag to view other items with the same tag. To keep tags manageable, add functionality to globally rename or merge tags. Optionally, implement social features: who added a tag to an item, who else uses a tag, what each person has tagged.
Tags are the poster child of Web 2.0 and, ironically, the least flashy and most useful of many of these features. Useful and not-flashy especially applies to del.icio.us which is the best source of ideas for how to use tags. For example, tags on a photo in Flickr :
However, tags are actually more interesting when you start tagging structured data, rather than just web pages via del.icio.us. By tagging structured data you are adding semi-structured meta-data to the structured data. For example, if your application’s database does not have a status field with ‘obsolete’ as an allowed value, you could simply tags items with an ‘obsolete’ tag. This would let you browse a list of obsolete items, in a way that would not be possible if you had merely added a comment that ‘this item is obsolete’.
Watch for changes - notifications
If the application knows the current user’s e-mail address, then give the user a simple way to ‘watch’ a particular page or data item, and notify the user of changes to that data by e-mail.
This is a good example of a useful feature that has a very simple user-interface - an icon with two states - and does not make the application more complex to use. Of course, this can require a lot of effort to implement, but that is another story.
The value of this feature is that in some applications, knowing when data changes is as useful as being able to find the current data. This also allows the application itself to become the focus of collaboration, because people can use the application to tell each other that data has changed, rather than make the change in some database and manually send an e-mail. (Or, more likely, just send an e-mail and not update the database.)
For example, if you use a wiki for reference information, you probably need to know when there is a new version. Each page in Confluence shows this envelope icon in the corner. When you click the inactive version (left), you start watching the page, the icon changes to the active version (right) and whenever anyone edits the page you get notified by e-mail.
Recent changes
In a multi-user application, show a list of recent activity for all users on the home page. For a content-based web application this means new and updated pages, and comments; for a catalogue system, show updates to catalogue items.
Initially, the recent changes list appears to just mimic the Recent Documents list in desktop applications, in order to provide a short cut to data that you were recently working on. However, in a collaboration application - where multiple users work on the same data - changes made by other people turn out to be more interesting.
The key benefit of this functionality is that it provides a simple and immediate answer to questions about how much activity there is, who is working on what, what has changed recently, and which topics are currently hot. To show who is doing what, the list entries must indicate who made the update. To show how much activity there is, and how recently (e.g. today), entries must indicate their age; ages like ‘2 hours ago’ or ‘13 days ago’ are more useful than dates and times here. To expose current topics, show a category for each entry.
For example, the Codehaus Confluence shows recent updates like this on its dashboard:
One special case is a wiki: if you cannot customise the home page the way you can with Confluence’s dashboard , then use the wiki’s Recent Updates page as your home page. By extension, on a company intranet, which should be a wiki, make a list recent changes half of its home page.
User-interface features
Despite the inevitable focus on Ajax in the Web 2.0 story, few of the important web application 2.0 features are purely in the user-interface.
Dashboard
Make the application home page, for logged in users, an overview of the currently most-interesting data. This can be context-sensitive, by being dependent on the current user and the current date. Consider data aggregation and high-level statistics, recent changes and the results of key searches. Optionally, implement a Portlet interface that allows the user to customise the dashboard by choosing Portlets, also know as widgets these days.
The idea of a dashboard is that instead of presenting a single view (or report) on the application’s data, it presents many concise summaries of the data, each addressing a different question. Ideally, these are task related, so that the dashboard effectively incorporates a to-do list of application-related tasks. This is related to the kind of content the front page of a web site has. Interestingly, management dashboards often have a ‘dumbed down toy’ image among software developers, which may explain why they are not more popular in web applications.
For example, JIRA has a sophisticated dashboard that lets you mix and match different Portlets for different views on your projects. The task-list aspect is that you can view overviews of outstanding issues of software development projects, such as a the ‘number of unresolved bugs per project’, or a list of ‘issues assigned to me’.
Similarly, discussion forum software often has a dashboard that shows lists of most read, recent and unanswered posts.
Favourites
In an application where you need to repeatedly return to particular items that are difficult to find, allow users to add an item/page to their ‘Favourites’, and make these items easily accessible from the home page.
This makes sense in applications where there is a small collection of ‘things I am currently working on’, while finding those items is inconvenient or difficult. This may be because the total number of items is large, because they do not have memorable names or locations to search for, or because you use the application too infrequently to remember what they were.
It is usually a bad idea to duplicate standard web browser functionality in a web application. Provided that your web application has bookmarkable URLs, you could simply use the browser’s bookmarks functionality instead. However, web browser bookmarks support remains primitive: it does not let you easily browse just bookmarks in the current site/application, or sort them with recent additions first. Another advantage of listing favourites in the application is that the application can annotate each one with more information, as for the Recent Changes described above, such as each favourite’s category.
Note that favourites can be combined with watching for changes, so that you get notified of changes to your favourites without a separate user-interface for turning on notifications.
In-line editing
Make some data editable using an Ajax click-to-edit control, such as the Dojo Inline Edit Box , rather than using a separate edit page.
This can make it more convenient to make edits to simple data that does not need a complex interface, such as a short piece of text like a title. This is not the case, however, when the editing task involves several attributes at the same time, in which case a separate edit mode is better. An intermediate possibility, of course, is a group of fields that all become editable when you click any of them.
For example, when you are logged in to Flickr , you can edit a photo’s description simply by clicking it:
发表评论
-
RSS
2006-05-13 13:33 811<?xml version="1.0" ... -
Java Session
2006-05-13 13:50 876web-app implements HttpSessio ... -
iFrame can't save session & cookie
2006-05-29 13:46 805RT so iFrame not suit of use. ... -
HTML/CSS/JavaScript code
2006-07-30 09:01 10341. oncontextmenu="windo ... -
IE与Firefox下对CSS解析的区别
2006-08-22 13:38 12441、IE与Firefox下对CSS解析 ... -
Web application 2.0 features (1)
2008-07-02 01:39 888After you have built the initia ... -
二级域名间用户信息存取,SSO
2008-07-18 11:21 1227采用cookie方式记录用户信息,其可以在二级域名之间存取。 ... -
Apache 防盗链(Apache Anti-Leech)技术的简单实现
2008-07-18 11:23 1467一. 使用 rewrite 技术实现 Apache 防盗链 ... -
url rewrite
2008-07-25 13:13 1063http://urlrewritefilter.googl ... -
xfire开发web service及调用
2008-08-21 11:34 1156xfire配置service <servi ...
相关推荐
■CHAPTER 10 Implementing Web 2.0 Features . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 335 ■CHAPTER 11 A Dynamic Image Gallery . . . . . . . . . . . . . . . . . . . . . . . . . . . . ...
Practical Apache Struts 2 Web 2.0 Projects shows you how to capitalize upon these new features to build next–generation web applications that both enthrall and empower your users. <br>Gain an in...
2. **使用New Web Application Project Wizard**:这个向导允许您创建一个新的使用Google Web Toolkit (GWT) 和/或 Google App Engine 的Web应用程序。 - 您可以选择项目名称和根包名。 - 项目的名称将用于生成...
Suitable for modern web browsers it provides a robust API for web application development. It is fast becoming the tool of choice for web developers the world over and sets the standard for ...
JSP 2.0 Tag Demos A web application that demonstrates use of a key JSP 2.0 features such as custom tag libraries using tag-files.
Get to grips with the features of Zend Framework 2’s MVC architecture Filter and validate data no matter what the content is Handle and manage file uploads Gather content from other websites Fight ...
Animation GIF ActiveX 2.0 has many new features including AutoSize, Stretch, custom playing sequence (reverse, pingpong or user-defined), etc. You can bind the GIF property in version 2.0 to database ...
Write RESTfull Web Services using Yii2 and built-in features Correctly install and use official extensions in your projects Effectively create and implement your own Yii extension, and also ensure ...
This book covers the latest technologies such as Advance XSS, XSRF, SQL Injection, Web API testing, XML attack vectors, OAuth 2.0 Security, and more involved in today's web applications Penetrate and ...
- **Configuring Web Application Settings**: PowerShell can be used to configure various web application settings, including authentication, SSL certificates, and web application throttling. ...
Publish data science work as a web application, and affect meaningful change in your organization. Build value from your data in a series of agile sprints, using the data-value pyramid Extract ...
Infragistics.NetAdvantage.for.ASP.NET.2008.Vol.2.CLR.2.0.Source.Retail-ZWT NetAdvantage for .NET is our comprehensive suite of ASP.NET and Windows Forms controls, components, and tools for the .NET ...
8: PART 2 – .NET CORE 2.0 AND .NET STANDARD 2.0 9: UNDERSTANDING AND PACKAGING .NET STANDARD TYPES 10: USING COMMON .NET STANDARD TYPES 11: WORKING WITH FILES, STREAMS, AND SERIALIZATION 12: ...