Display html locally in a browser
use strict; use HTML::Display; # guess the best value from $ENV{PERL_HTML_DISPLAY_CLASS} # or $ENV{PERL_HTML_DISPLAY_COMMAND} # or the operating system, in that order my $browser = HTML::Display->new(); warn "# Displaying HTML using " . ref $browser; my $location = "http://www.google.com/"; $browser->display(html => $html, location => $location); # Or, for a one-off job : display("<html><body><h1>Hello world!</h1></body></html>");
This module abstracts the task of displaying \s-1HTML\s0 to the user. The displaying is done by launching a browser and navigating it to either a temporary file with the \s-1HTML\s0 stored in it, or, if possible, by pushing the \s-1HTML\s0 directly into the browser window.
The module tries to automagically select the \*(L"correct\*(R" browser, but if it dosen't find a good browser, you can modify the behaviour by setting some environment variables :
PERL_HTML_DISPLAY_CLASS
If HTML::Display already provides a class for the browser you want to use, setting \*(C`PERL_HTML_DISPLAY_CLASS\*(C' to the name of the class will make HTML::Display use that class instead of what it detects.
PERL_HTML_DISPLAY_COMMAND
If there is no specialized class yet, but your browser can be controlled via the command line, then setting \*(C`PERL_HTML_DISPLAY_COMMAND\*(C' to the string to navigate to the \s-1URL\s0 will make HTML::Display use a \*(C`system()\*(C' call to the string. A %s in the value will be replaced with the name of the temporary file containing the \s-1HTML\s0 to display. The hash %HTML::Display::os_default contains pairs of class names for the different operating systems and routines that test whether this script is currently running under it. If you you want to dynamically add a new class or replace a class (or the rule), modify %os_default :
# Install class for MagicOS $HTML::Display::os_default{"HTML::Display::MagicOS"} = sub { $^O =~ qr/magic/i }; Will display the \s-1HTML\s0. The following arguments are valid :
base => Base to which all relative links will be resolved html => Scalar containing the HTML to be displayed file => Scalar containing the name of the file to be displayed This file will possibly be copied into a temporary file!
location (synonymous to base)
If only one argument is passed, then it is taken as if
html => $_[0]
was passed.
The subroutine \*(C`display\*(C' is exported by default
Display some \s-1HTML\s0 to the user :
perl -MHTML::Display -e "display '<html><body><h1>Hello world</body></html>'"
Display a web page to the user :
perl -MLWP::Simple -MHTML::Display -e "display get 'http://www.google.com'"
Display the same page with the images also working :
perl -MLWP::Simple -MHTML::Display -e "display html => get('http://www.google.com'), location => 'http://www.google.com'"
Copyright (c) 2004-2007 Max Maischein \*(C`<[email protected]>\*(C'
This module is released under the same terms as Perl itself.