Tinkering with my blog as procrastination
I have a pile of things to write about so . . . I’m going to tinker with my blog instead. There are just a lot of little things that have been bugging me for awhile, so let’s see what I can take care rather than write what I really want to write about.
Fix slow images
I don’t use a lot of images on my blog, but when I do use them, I haven’t bothered to optimize them. As a result, pages like the sourdough analogy took far too long to load. After making this change, the PageSpeed increased from 87 to 98 on mobile. More importantly, I no longer need to watch these images load now that they are small enough to pop in nearly instantly. You know, like on my machine.
Since my blog runs on Jekyll, I searched for jekyll image
compression
. That led me to an answer on Stack
Overflow and a Jekyll
plugin. Trouble with the
plugin is that GitHub Pages doesn’t run it on their
service. I could do
the trick I used to get
tagging,
but the plugin also required some configuration to resize my
images. And I needed to change all my posts to use the special asset
Liquid tags. This was pretty quickly getting beyond my scope.
Like the prodigal son, I came to my senses. All I need to do is run an
ImageMagick command on all my
images. A few more searches brought me to this article about resizing
images
which helped me write a resize_images.ksh
script:
#!/usr/bin/env ksh
mkdir -p images
# https://www.smashingmagazine.com/2015/06/efficient-image-resizing-with-imagemagick/
smartresize() {
mogrify -path $3 \
-filter Triangle \
-define filter:support=2 \
-thumbnail $2\> \
-unsharp 0.25x0.08+8.3+0.045 \
-dither None -posterize 136 \
-quality 82 \
-define jpeg:fancy-upsampling=off \
-define png:compression-filter=5 \
-define png:compression-level=9 \
-define png:compression-strategy=1 \
-define png:exclude-chunk=all \
-interlace none \
-colorspace sRGB $1
}
for f in images_raw/*; do
t=`echo $f | sed -e 's/images_raw/images/g'`
if [ ! -f $t ]; then
cp $f $t
smartresize $t 740 images/
fi
done
This copies images from images_raw
to images
and transforms them
so that they are no bigger then 740 pixels wide. I made a slight
change to Dave
Newton’s
script. He designed it to resize images for responsive
design which
might mean making the image a bit bigger. But I mostly care about
making it fit into the width of my textblock, so I added the
greater-than symbol to -thumbnail $2\>
, which instructs ImageMagick
to only size the image down.
For my blog, which an audience of hundreds, this isn’t strictly necessary. My readers tend to be patient enough to wait a second or two for an image to load. Plus the text loads immediately so people can get to the words. But it’s the sort of thing that really kills a site like College Confidential. Our PageSpeed on mobil is 5. Out of 100. That’s “remember modems?” speed. Now our problem is not mostly images. We’re working to fix the problem because it really makes using the site, especially on your phone, unpleasant.
Use HTTPS links
This one is easier. When I started my blog, many sites didn’t support
HTTPS protocol. So I copied links that began http://
rather than
https://
. Since my pages are served via HTTPS, that creates a
potential security
problem. Also
Netlify sends me an email every
time I publish a new page.
Every page Jekyll builds has this problem because of a line in my _config.yml file:
author_url: http://meta.stackexchange.com/users/1438/jon-ericson
When I added that line, Stack Exchange had not yet moved to HTTPS. Since my URL is in the footer of every page and the byline of every post, I have a lot of mixed content problems. But I also have a lot of links in my posts that are HTTP. Thankfully, it’s fairly safe to fix them with a regex:
$ find _posts -name \*.md -exec perl -pi.bak -e 's|http://|https://|g' {} \;
A couple of caveats: I can’t use that script on this post because it
doesn’t actually make sure the string that is being changed is a
link. Using it now would mess up this post. Second, .bak
created a
bunch of backup files that aren’t really necessary since I’ve saved a
copy of the previous version in Git. Cleaning them requires another
find
command:
$ find _posts -name \*.bak | xargs rm
Note I used xargs
instead of the -exec
parameter. It’s been a long
time since I used the command line for this sort of work and I’d
forgotten how flexible xargs
is. I hadn’t forgotten to escape my
wildcards though.
Finally, so I wouldn’t have this problem in the future, I added the
enforce_https
test to my
Rakefile.
Accessibility concerns
I happen to know my blog has one regular reader who experiences problems when websites have poor contrast text. I’ve known my blog has this problem too, but I hadn’t gotten around to fixing it. Yes, my blog doesn’t have a large readership, but that means I lose a higher percentage of my audience if they can’t read my posts. (Not that that’s an excuse for Stack Overflow ignoring the problem.)
One easy test is to run a page through WAVE, the WebAIM web accessibility evaluation tool. I don’t have as many problems as I’d been afraid I would:
- 2 errors
- 20 contrast errors
- 1 alert
Document language missing
My blog is in English because that’s the language I’m comfortable writing in. That’s a pretty good default if the language isn’t specified. So my blog probably works fine for my readers. That said, this is one of these US-centric things that drives people in other countries mad. It’s also a single line change to my default layout:
<html lang="en-US">
Empty link
The Jekyll theme I chose included a menu across the top of each page. The menu includes the following link:
<a href="#" class="menu-icon">
Since I borrowed that code, someone has removed the empty link
target. So
I copied that change and removed the line in my Rakefile that allowed
bare hashes in href
attributes. That way I won’t make this mistake
again. Subsequent testing reminded me I needed to rebuild my tag pages
for this change to go into effect everywhere.
Contrast errors
I had two basic problems illustrated in this image:
First, there are problems with the level of grey my theme used. The contrast ratio is 3.77:1, which is less than the 4.5:1 recommended for small text. Thankfully the WAVE tool has a Contrast tab that lets me move a slider to find a dark enough text color.
Second, my link color was low contrast as well. The trick with links is the color must contrast with both the background and the main text. Ideally, the color when a link is followed also has sufficient contrast with surrounding text.
Redundant alternative text
This alert pointed out that the alt
text for my site icon was just
the site title, which isn’t actually that informative. So I changed it
to:
<img src="/images/donquixote.gif" alt="">
The icon itself carries no particular meaning. I suppose I could use the alt text to explain that it’s Pablo Picasso’s Don Quixote sketch. That would explain the title, I suppose. But is it worth time when the rest of the post is about something completely different? Is the joke itself worth it for people who can see the image?
To prevent HTMLProofer from flagging this empty alt text, I added an exception:
:alt_ignore => ['/images/donquixote.gif'],
Why bother?
So much of the world is imperfect and beyond the control of any one person. Building you own website creates a space you can own. No it won’t be perfect, but it won’t be constrained by the sort of things that limit other sites. With a proliferation of free and inexpensive hosting options, there’s no reason not to claim a bit of territory on the internet. And if you have your own site, you might as well do what you can to perfect it.
For feedback, see this GitHub issue.