This is the 8th day of my participation in the August Text Challenge.More challenges in August
First, menu route jump
To redirect a route, add the Router attribute to the EL-Menu TAB.
Then, just set the URL in the index attribute of each el-Menu-item tag to realize the route jump by clicking el-Menu-item.
Of course, you can also set the URL of the router attribute in each el-Menu-item tag to achieve the jump and cut priority higher than index.
Two, whether to keep only one submenu expansion configuration error
- Configuration:
<el-menu unique-opened = true>
- Error:
Invalid prop: type check failed for prop "uniqueOpened". Expected Boolean, got String.
- To:
<el-menu :unique-opened = true> <el-menu :unique-opened = "true">
Modify the Element-UI style
Because the official documentation is not detailed, for example, the official documentation does not say how to set the width of el-aside.
> < span style=”width:210px”;
Here’s the problem: I click on a button and change the width of el-Aside via jequery or global variable control. Style =”width:210px” style=”width:210px”
The only solution is to change the elder-UI style and then use jQ to change the width of the el-Aside element. No matter how much the timer setTimeout refreshes, it will not affect the current style.
Note here:
- When changing a style using global variable control, you will see a lag. Finally, you will choose to use jequery’s.css or.animate method.
- 2. SetTimeout is more memory friendly than setInterval.
- 3, Let’s talk about how to modify the element-UI style through formal channels: if there is no official API documentation, you can only look at the source code.
For example, to change the width of the el-aside, find the file \node_modules\element-ui\packages\aside\index, there is nothing, introduce the aside from ‘./ SRC /main’;
Continue to view the file./ SRC /main
<aside class="el-aside" :style="{ width }">
<slot></slot>
</aside>
Copy the code
As you can see above, el-aside can be set to modify the width
props: {
width: {
type: String,
default: '300px'
}
}
Copy the code
210px must be converted to String in single quotation marks.
4. Border-image causes that the border of the el-table header is sometimes absent
- El-table__header left and right borders are sometimes not displayed
- Difference: table head height width is not the same
- Border-image: linear gradient(150deg, #1ddae4, # 2698EC) 30 30; border-image: linear gradient(150deg, #1ddae4, # 2698EC) 30 30;
- Border-image: linear-gradient(150DEg, # 1dDAe4, # 2698EC) 5;
Just…
The reason:
Border-image: Linear-gradient () the following four parameters indicate top right bottom left respectively
Some height and width limits must not exceed the height and width of the outer div. However, for the specific limits, I have tried the following blog post, but it is still wrong, and I cannot find other information for the time being.
www.cnblogs.com/zhangdongya…
Including the four parameters 30, 30px, 1/30px, why the middle one doesn’t work, and what the other two display separately is not clear. Ah.
Element tag el-SELECT is invalid
When using the element tag, ensure that the string and number types correspond to each other.
<el-select V-model ="validTime" clearable placeholder=" placeholder "> <el-select V-model ="item in validTimeData" :key="item.value" :label="item.label" :value="item.value"></el-option> </el-select>Copy the code
[{validTimeData = “label” : “20 minutes”, “value” : “20”}, {” label “:” five minutes “, “value” : “5”}]
When validTime = “20”, the normal 20 minutes is displayed.
If validTime = 20, the label corresponding to 20 cannot be found, so 20 is displayed.
Element UI form rules validation
< EL-form :model="deviceBox" :rules="rules" ref="deviceBox"> <el-form-item label=" device name" prop="name"> < EL-input V-model ="deviceBox. Name "></el-input> </el-form-item> rules: {name: [{required: true, message: 'Please enter device name ', trigger: 'blur'}, {min: 3, Max: 25, message: 'length between 3 and 25 characters '}]}Copy the code
- 1, the model, rules, ref attributes are essential
- 2. The prop property value of prop must be consistent with that of V-Model
- For details, see github.com/yiminghe/as…
Dom has no width or height
Thinking process:
- El-tabs__content can’t add width 100%;
- El-tabs add border: 1px solid green; Then normal, very strange;
- At the same time, it is found that the div inside echarts does not get the height, but can get the width normally.
- The echarts div class does not have a height and width of 100%, nor does it have a width of 600px. Only the style div is 600px, or the class is 600px! Important.
And then you realize 100%! Important is ok, but it may be true that 100% is only so high, but why does the 100% height of each layer have no height at this point?
El-tabs__content layer: position: relative!
It is ok to change the halo to absolute, but the original style of the plug-in is messed up and you have to adjust it slowly.
- fixed
- Generates an absolutely positioned element, positioned relative to the browser window.
- The position of the element is specified by the “left”, “top”, “right”, and “bottom” attributes.
- static
- Without positioning, the element appears in the normal stream (ignoring the top, bottom, left, right, or Z-index declarations).
- inherit
- Specifies that the value of the position attribute should be inherited from the parent element.
- relative
- Generates a relatively positioned element that is positioned relative to its normal position.
- Therefore, “left:20” adds 20 pixels to the left position of the element.
- absolute
- Generates an absolutely positioned element relative to the first parent element other than the static positioned element.
- The position of the element is specified by the “left”, “top”, “right”, and “bottom” attributes.
Default-expanded -keys in the Element tree cannot be modified once loaded
El-tree is usually used as follows:
<el-tree ref="tree" :default-expanded-keys="[defaultId]"></el-tree> <el-dialog :visible.sync="deptVisible" append-to-body> <my-tree> <el-tree ref="tree" :default-expanded-keys="[defaultId]"></el-tree> </my-tree> </el-dialog>Copy the code
Here’s a question:
When initializing the El-Tree, assign defaultId to the default expansion. The pop-up box closes and pops up again. The default expansion of the El-Tree remains the same even if defaultId is changed.
Try to modify:
DefaultId changes when the parent component calls the child component to set the selected value and the current highlight value, as follows
this.$refs.tree.setCheckedKeys([defaultId])
this.$refs.tree.setCurrentKey(defaultId)
Copy the code
When the popup is closed and opened, defaultId is changed, indeed the selected and highlighted items are changed, but the previous expansion items are still open!!
Baidu found:
Segmentfault.com/q/101000001…
Neither tree nor tree-store provides a way to collapse nodes…
So I thought:
Traversal is impossible, but I can update or reload the El-Tree!
Learn about the VUE lifecycle:
The updated is triggered when the data in the data is changed, not the props passed by the parent component. The props is one-time, so the updated is hopeless.
Note that if you look at the source code, you can see that the V-show used by the Element component’s dialog method hides only the dialog part, so even if the dialog is closed, the components inside it are not destroyed.
Then I can make the tree destroy by v-if while the dialog is hidden.
The following Settings can be used:
<el-dialog :visible.sync="deptVisible" append-to-body>
<my-tree v-if="deptVisible"></my-tree>
</el-dialog>
Copy the code
El-table width drag function
The official document has the following table-column Attributes:
Resizable: Whether the width of the corresponding column can be changed by dragging (need to set the border property to true on the EL-table)
Show-overflow-tooltip: Displays tooltip when content is too long and hidden
Note:
- The table-column attribute is set on the tag.
- 2, To use resizable drag to change width, you must set the attribute “border” to true on the EL-table.
Such as:
<el-table elemental-loading-text =" loading-elemental-loading-text" ref="table" :data="tableData" highlight-current-row :border="true"> <el-table-column v-for="column in columns" :key="column.id" :property="column.prop" :label="column.name" :resizable="true" show-overflow-tooltip> </el-table-column> </el-table>Copy the code
10. Clearing floats is important
There is a problem with using the el-form layout. If you want to split the layout into two columns, one on the left and one on the right, and one at the bottom, it looks like this:
<el-form label-width="80px" size="mini"> <div class="info-left"> <el-form-item label=" device ID:">< EL-input v-model="devInfo.info.id"></el-input></el-form-item> </div> <div class="info-right"> <el-form-item Label =" Device type :"><el-input V-model =" devinfo.info.dtype "></el-input></el-form-item> </div> <el-form-item label=" Remarks :"> <el-input type="textarea" v-model="devInfo.info.remarks"></el-input> </el-form-item> </el-form> .el-form .info-left { width: 49%; float: left; } .el-form .info-right { width: 49%; float: right; }Copy the code
Then I found that, except for the remarks at the bottom, the above two columns could not be input and used normally. Why is that? I don’t know. That’s weird. Suddenly realized that the above left and right columns did not clear float ah, clear the results as expected good ah.
<el-form label-width="80px" size="mini"> <div class="info-left"> <el-form-item label=" device ID:">< EL-input v-model="devInfo.info.id"></el-input></el-form-item> </div> <div class="info-right"> <el-form-item <el-input V-model =" devinfo.info.dtype "></el-input></el-form-item> </div> <div style="clear:both"></div> <el-form-item label=" Remarks :"> <el-input type="textarea" V-model =" devinfo.info.remarks "></el-input> </el-form-item> </el-form>Copy the code
Conclusion: Clearing floats is really important!!
In addition:
If the el-tabs and other components are used, firefox also displays an abnormal height. If the height of a DIV is abnormal, perform the following steps to rectify the fault:
- 1. Determine the percentage exception and check whether the outer div is set to height and width.
- 2. Check whether floating exists.
- 3. Check whether the setting of position is reasonable.
$this.$confirm
<a href="#" @click="downloadDoc"><i class="iconfont" > </ I ></a> downloadDoc () {this.$confirm(' Do you want to download help? ', 'download ', {confirmButtonText:' confirm ', cancelButtonText: 'cancel ', type: 'info'}).then(() => {this.helpDocDownload() this.$message({type: 'success', message: 'Download successful! '})}). The catch (() = > {enclosing $message ({type: 'info', the message: 'have to cancel the download'})})}Copy the code
When you click label A for the first time, the pop-up box will flash back, and click normal again.
Because the href=”#” is positioned at the top of the page, it appears, clicking on the outside of the popup will cause the popup to exit and close.
Change the label to the following:
<a href="javascript:void(0)" @click="downloadDoc"><i class="iconfont" > </i></a>Copy the code
Error $message
Error code:
Vue.prototype.$message.info(res.data.errorMessage)
Copy the code
Error message:
TypeError: Cannot set property 'type' of undefined at Function.Message.<computed> [as info] (element-ui.common.js?ccbf:26452) at Eval (index.js?16ca:126) "Get request error!"Copy the code
Correct code:
Vue.prototype.$message(
{
type: 'info',
message: res.data.errorMessage
}
)
Copy the code
The colon binding value problem
When binding property values in VUE, for example
<el-dialog :title="dialogTitle"></el-dialog>
Copy the code
1. If title is not preceded by a colon:
<el-dialog title="dialogTitle"></el-dialog>
Copy the code
It’s going to be treated as HTML text as a string, which is title and it’s going to render as a string, dialogTitle
2. If title is preceded by a colon:
<el-dialog :title="dialogTitle"></el-dialog>
Copy the code
Will be treated as a template and will be filled in during rendering.
so
If dialogTitle is a numeric value or a Boolean value, the title must be preceded by a colon, for example:
<el-dialog :title="true"></el-dialog>
<el-dialog :title="101"></el-dialog>
Copy the code
Otherwise it will be treated as strings true and string 101.