Vector
The Vector object is provided to address some short-comings in ActiveX scripting's array support. Some languages have better support than others for arrays, but the languages aren't consistent and some (like JScript) have incompatible arrays that Opus is unable to access at all. Therefore, any Opus scripting objects that take or return an array-like variable will use (or prefer to use) a Vector rather than an array.
A Vector object is mostly able to be used as a straight drop-in replacement for an arrays. They are collections and so can be enumerated, or accessed via index (e.g. Vector(4) to access the fifth element). They also have a number of helper methods to make manipulating them easier than arrays often are.
Note that in JScript you can access an element using square brackets (just like an array) or parentheses (as if it was a function parameter). In other languages, like VBScript, you can only use parentheses.
You can create a new Vector using the DOpusFactory.Vector method.
capacity
int
Returns the capacity of the Vector (the number of elements it can hold without having to reallocate memory). This is not the same as the number of elements it currently holds, which can be 0 even if the capacity is something larger.
count
int
Returns the number of elements the Vector currently holds.
empty
bool
Returns True if the Vector is empty, False if not.
length
int
A synonym for count.
size
int
A synonym for count.
Method Name
Arguments
Return Type
Description
append
<Vector:from> <int:start> <int:end>
none
Copies the values of another Vector to the end of this one, preserving the existing values as well. If start and end are not provided, the entire Vector is appended - otherwise, only the specified elements are appended.
Instead of a Vector object you can also pass a collection to this method and the contents of the collection will be copied to the end of the Vector. In JScript you can pass a standard array to this method to copy the array to the end of a Vector.
assign
<Vector:from> <int:start> <int:end>
none
Copies the value of another Vector to this one. If start and end are not provided, the entire Vector is copied - otherwise, only the specified elements are copied.
Instead of a Vector object you can also pass a collection to this method and the contents of the collection will be copied to the Vector.
In JScript you can pass a standard array to this method to copy the array into a Vector.
back
none
variant
Returns the last element in the Vector.
clear
none
none
Clears the contents of the Vector.
erase
<int:index>
none
Erases the element at the specified index.
exchange
<int:index1> <int:index2>
none
Exchanges the positions of the two specified elements.
front
none
variant
Returns the first element in the Vector.
insert
<int:index> <variant:value>
none
Inserts the provided value at the specified position.
pop_back
none
none
Removes the last element of the Vector.
push_back
<variant:value>
none
Adds the provided value to the end of the Vector.
reserve
<int:capacity>
none
Reserves space in the Vector for the specified number of elements (increases its capacity, although the count of elements remains unchanged).
Note that Vectors grow dynamically - you don't have to specifically reserve or resize them. However if you want to add a large number of elements to a Vector it can be more efficient to reserve space for them first.
resize
<int:size>
none
Resizes the Vector to the specified number of elements. Any existing elements past the new size of the Vector will be erased.
reverse
none
none
Reverses the order of the elements held by the Vector.
shrink_to_fit
none
none
Reduces the capacity of the Vector to the number of elements it currently holds.
sort
none
none
Sorts the contents of the Vector. Strings and numbers are sorted alphabetically and numerically - other elements are grouped by type but not specifically sorted in any particular order.
unique
none
int
Removes all but one of any duplicate elements from the Vector. The number of elements removed is returned.
最后更新于