This is a repost of my fragmentions for poets post, with a nav bar added to the top, to illustrate the problem with scrolling and nav bars -that the scrolled text is hidden by the fixed-position navbar, so when I click on the header links they are under the navbar.
This is the fixed version. Broken version
Fragmentions for poets
Since the original fragmention implementation and discussion, we've been trying it out in various contexts, including any wordpress blog, Shakespeare's complete works and even the indiewebcamp wiki. Also there have been a lot of reactions and suggestions. Some of these occur often enough that I thought I'd write some responses down.
What if the linked-to text changes?
Several people pointed to the New York Times Emphasis project, which builds IDs from initial letters of sentences in a paragraph to provide some degree of resilience against the linked-to text being changed. It also tries using edit distances if it can't find the text.
Whether you still want to link to changed text is a tricky problem - if it has completely been removed, then the annotation or point of linking may have gone (pointing out a typo, or misstatement). Even a small change (adding the word 'not' for example) can mean that the point of linking has changed, so my first thought is that changing the text breaking the link can be reasonable.
If you want some fuzzy matching to go on, having more of the linked-to text in the fragment can only help the linked-to page identify where in the text was intended. Indeed, if enough is included, you could show the difference between what was linked to and what is there now.
Recurring text
What if the linked-to text occurs more than once?
By default, go to the first instance. If you want a different link, use more words to create a unique reference. While there have been proposals to link to the nth occurrence using more complex syntax, I don't think this is actually a natural choice, and likely to be more fragile. The NYT Emphasis tool mentioned above switched from a nth sentence type model to a content dependent one for this reason; fragmentions simplify and extend this idea.
I have tried to come up with a use case that fits this goal - the closest I can think of is referring to a particular repetition of a line of poetry, for example in a villanelle.
I can link to the 3rd line of the 1st verse by citing it in full. If I wanted the final line, linking to it and the line before would work. I think this is clear, though linking to night & Rage would be enough.
The only reason I can think of to link to specific lines would be to discuss them in the context of surrounding lines, so I think this works adequately.
If a tool is made to allow readers to construct a link to a specific phrase, indicating that that phrase is not unique to encourage them to choose a longer phrase may be worth it.
Could you combine an id and a fragmention?
A link of form #id##some+words has been suggested, but again I'm not sure I see the utility. This is the nth occurrence idea in a different guise. It combines two addressing models in one, making it harder to construct and more fragile to resolve.
Can we get rid of ## and just use #?
The other thought, based on closer reading of the HTML5 spec ID attribute:
is that we may not need the ## (which technically makes an invalid URL) at all.The
idattribute specifies its element's unique identifier (ID). [DOM]The value must be unique amongst all the IDs in the element's home subtree and must contain at least one character. The value must not contain any space characters.
There are no other restrictions on what form an ID can take; in particular, IDs can consist of just digits, start with a digit, start with an underscore, consist of just punctuation, etc
If an HTML5 id cannot contain a space, then a fragment that contains one like #two+words can never match an id (as id="two words" would be invalid). If it can't be an id it should be treated as a fragmention.
If you really want a one-word fragmention a trailing space like #word+ could be used.
This means that the idea of fragmention could be simplified: if a fragment contains a space it MUST be a fragmention, and should be searched for in the text. If it doesn't match any IDs in the page, it COULD be a fragmention and should be searched for in the text anyway.
Fragmentions become a fallback to be used when an id can't be found.
Do not go gentle into that good night
Do not go gentle into that good night, 
Old age should burn and rave at close of day; 
Rage, rage against the dying of the light. 
Though wise men at their end know dark is right, 
Because their words had forked no lightning they 
Do not go gentle into that good night. 
Good men, the last wave by, crying how bright 
Their frail deeds might have danced in a green bay, 
Rage, rage against the dying of the light. 
Wild men who caught and sang the sun in flight, 
And learn, too late, they grieved it on its way, 
Do not go gentle into that good night. 
Grave men, near death, who see with blinding sight 
Blind eyes could blaze like meteors and be gay, 
Rage, rage against the dying of the light. 
And you, my father, there on the sad height, 
Curse, bless, me now with your fierce tears, I pray. 
Do not go gentle into that good night. 
Rage, rage against the dying of the light.
by Dylan Thomas