- Editing entry reformats the text multiplying nine breaks on image upload... So i have manually go line by line and delete it...
- Added image always appears on entry begin... So it is necessary take it and drag down down and down until the place where i need it.
- No possibility to add a table... Editing source manually and writing <table&gh; there results in huge gap before the table (a screen or two)... Later i discovered that it is possible to insert a table copying it from Word and pasting to Firefox. But after saving it looks just awful in Internet Explorer!
- Also applying different font does not always work (when begin and end of selection have same font as you've chosen to format - the inside is not formatted).
- Sometimes you font drop down disappears at all and sometimes it shows no options to choose from.
Thursday, November 29, 2007
Disapointment... Moving to WordPress
Tuesday, November 27, 2007
Mozilla/Firefox Range - Part 1: setEndAfter Mythic
Range endOffset Property and setEnd Method
Range setEndAfter Method
The setEndAfter Mythics
Range endOffset Property and setEnd Method
Let's consider next Range properties:
- range.endContainer – points to the node where the range ends.
- range.endOffset – is shift inside the endContainer to point exactly to the place where range ends
- range.setEnd(newEndContainer, newEndOffset) – sets new end boundary of the range.
The prevalent errors are made here when misunderstanding endOffset property.
EndOffset is the index of node or character right before which is the end of the range and this node or character does not belong to the range itself (not the index of last range node or character!!)
The second important point here is that this node or character before the end may not even exist.
Example:
Suppose some range contains some text node (dayNode.nodeType = “#text”).
For example dayRange contains text node with textContent ‘day’.
- commonAncestorContainer - Text node ‘day’
- startContainer - Text node ‘day’
- startOffset - 0
- endContainer - Text node ‘day’
- endOffset - 3
Lets suppose dayNode is a child of a dayWrapperNode (the only one child).
After calling
- commonAncestorContainer - dayWrapperNode
- startContainer - Text node 'day'
- startOffset - 0
- endContainer - dayWrapperNode
- endOffset - 1
Note that commonAncestorContainer has also changed to dayWrapperNode.
It might seem strange that range whose text content ex facte is completely in text node, (dayRange) is reached out from the dayNode to next sibling of the parent node. Cool yeah? But it is the way how it is implemented.
It is hard to understand, but something mythical happens with setEndAfter method.
Question 2: what is expected result of calling:
As dayRange.endContainer and dayRange.startContainer point to same node, it is natural to expect that results of execution any of those operations will be the same.
But… no – they, are not the same.
In the former case dayRange.startContainer will point to dayWpapperNode.childNodes[1]:
Question 3: what is expected result of executing this:
?
The answer is awesome! The result is same as calling
dayRange.setEndAfter(dayRange.startContainer);
i.e. it will point to dayWpapperNode.childNodes[1].
And now... will somebody tell me that Javascript programming isn't great? There are so many unknown and hidden features to take over in order to be a master....