[#]: subject: "Improve your documentation with JavaScript" [#]: via: "https://opensource.com/article/22/12/dynamic-documentation-javascript" [#]: author: "Jim Hall https://opensource.com/users/jim-hall" [#]: collector: "lkxed" [#]: translator: "duoluoxiaosheng" [#]: reviewer: " " [#]: publisher: " " [#]: url: " " Improve your documentation with JavaScript ====== Open source software projects often have a very diverse user group. Some users might be very adept at using the system and need very little documentation. For these power users, documentation might only need to be reminders and hints, and can include more technical information such as commands to run at the shell. But other users may be beginners. These users need more help in setting up the system and learning how to use it. Writing documentation that suits both user groups can be daunting. The website's documentation needs to somehow balance "detailed technical information" with "providing more overview and guidance." This is a difficult balance to find. If your documentation can't meet both user groups, consider a third option — dynamic documentation. Explore how to add a little [JavaScript][1] to a web page so the user can choose to display just the information they want to see. ### Structure your content You can use the example where documentation needs to suit both expert and novice users. In the simplest case, you can use a made-up music player called AwesomeProject. You can write a short installation document in HTML that provides instructions for both experts and novices by using the class feature in HTML. For example, you can define a paragraph intended for experts by using: ```
``` This assigns both the expert class and the reader class. You can create a parallel set of instructions for novices using: ```
``` The complete HTML file includes both paragraphs for novice readers and experts: ```
Thanks for installing AwesomeProject! With AwesomeProject, you can manage your music collection like a wizard.
But first, we need to install it:
You can install AwesomeProject from
source. Download the tar file, extract it, then run:
./configure ; make ; make install
AwesomeProject is available in most Linux distributions. Check your graphical package manager and search for AwesomeProject to install it.
``` This sample HTML document doesn't have a stylesheet associated with it, so viewing this in a web browser shows both paragraphs: ![Image of html in black text.][2] We can apply some basic styling to the document to highlight any element with the reader, expert, or novice classes. To make the different text classes easier to differentiate, let's set the reader class to an off-white background color, expert to a dark red text color, and novice to a dark blue text color: ```Thanks for installing AwesomeProject! With AwesomeProject, you can manage your music collection like a wizard.
But first, we need to install it:
You can install AwesomeProject from
source. Download the tar file, extract it, then run
./configure ; make ; make install
AwesomeProject is available in most Linux distributions. Check your graphical package manager and search for AwesomeProject to install it.
``` With these controls in place, the web page now allows the user to select the text they want to see: ![Image of window that allows you to select between novice and expert text.][4] Clicking either button will show just the text the user wants to read. For example, if you click the “view novice text” button, then you'll see just the blue paragraph: ![Image showing blue text when you press the novice button.][5] Clicking the “view expert text” button hides the novice text and shows only the expert text in red: ![Image of red text after the expert button is clicked.][6] ### Extend this to your documentation If your project requires you to write multiple how-to documents for different audiences, consider using this method to publish once and read twice. Writing a single document for all your users makes it easy for everyone to find and share the documentation for your project. And you won't have to maintain parallel documentation that varies in just the details. -------------------------------------------------------------------------------- via: https://opensource.com/article/22/12/dynamic-documentation-javascript 作者:[Jim Hall][a] 选题:[lkxed][b] 译者:[译者ID](https://github.com/duoluoxiaosehng) 校对:[校对者ID](https://github.com/校对者ID) 本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出 [a]: https://opensource.com/users/jim-hall [b]: https://github.com/lkxed [1]: https://opensource.com/downloads/learn-javascript [2]: https://opensource.com/sites/default/files/2022-12/publishonec.textblack.png [3]: https://opensource.com/sites/default/files/2022-12/publishone.red_.blue_.png [4]: https://opensource.com/sites/default/files/2022-12/publishone.novicexpert.png [5]: https://opensource.com/sites/default/files/2022-12/publishone.blue_.png [6]: https://opensource.com/sites/default/files/2022-12/publishone.red_.png