2026-02-15 18:15:42 +08:00
|
|
|
|
<script setup>
|
|
|
|
|
|
import { ref } from 'vue'
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
const basicStep = ref(0)
|
2026-02-15 18:15:42 +08:00
|
|
|
|
const basicA = ref(10)
|
|
|
|
|
|
const basicB = ref(null)
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
const refStep = ref(0)
|
|
|
|
|
|
const objData = ref({ age: 25 })
|
2026-02-15 18:15:42 +08:00
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
const basicCopy = () => { basicB.value = basicA.value; basicStep.value = 1 }
|
|
|
|
|
|
const basicModify = () => { basicB.value = 20; basicStep.value = 2 }
|
|
|
|
|
|
const basicReset = () => { basicStep.value = 0; basicB.value = null }
|
2026-02-15 18:15:42 +08:00
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
const refCopy = () => { refStep.value = 1 }
|
|
|
|
|
|
const refModify = () => { objData.value.age = 30; refStep.value = 2 }
|
|
|
|
|
|
const refSpread = () => { refStep.value = 3 }
|
|
|
|
|
|
const refReset = () => { refStep.value = 0; objData.value.age = 25 }
|
2026-02-15 18:15:42 +08:00
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
|
|
<template>
|
|
|
|
|
|
<div class="reference-demo">
|
2026-02-17 01:39:59 +08:00
|
|
|
|
<div class="demo-title">🔄 值 vs 引用</div>
|
|
|
|
|
|
|
|
|
|
|
|
<div class="compare-grid">
|
2026-02-15 18:15:42 +08:00
|
|
|
|
<!-- 左侧:基本类型 -->
|
2026-02-17 01:39:59 +08:00
|
|
|
|
<div class="compare-box">
|
|
|
|
|
|
<div class="box-header blue">基本类型(复制值)</div>
|
|
|
|
|
|
|
|
|
|
|
|
<div class="memory-area">
|
|
|
|
|
|
<div class="vars-row">
|
|
|
|
|
|
<div class="var-item" :class="{ active: basicStep >= 0 }">
|
|
|
|
|
|
<span class="var-label">a</span>
|
|
|
|
|
|
<span class="var-val">{{ basicA }}</span>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="var-item" :class="{ active: basicStep >= 1, changed: basicStep >= 2 }">
|
|
|
|
|
|
<span class="var-label">b</span>
|
|
|
|
|
|
<span class="var-val">{{ basicB ?? '?' }}</span>
|
|
|
|
|
|
</div>
|
2026-02-15 18:15:42 +08:00
|
|
|
|
</div>
|
2026-02-17 01:39:59 +08:00
|
|
|
|
<div class="copy-arrow" v-if="basicStep >= 1">↓ 复制值</div>
|
2026-02-15 18:15:42 +08:00
|
|
|
|
</div>
|
2026-02-17 01:39:59 +08:00
|
|
|
|
|
|
|
|
|
|
<div class="result-text" :class="basicStep === 2 ? 'success' : 'info'">
|
|
|
|
|
|
{{ basicStep === 0 ? '点击复制' : basicStep === 1 ? 'b 得到 10' : '✅ 修改 b 不影响 a' }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<div class="btn-group">
|
|
|
|
|
|
<button @click="basicCopy" :disabled="basicStep >= 1">复制</button>
|
|
|
|
|
|
<button @click="basicModify" :disabled="basicStep !== 1">改 b</button>
|
|
|
|
|
|
<button @click="basicReset" class="reset">重置</button>
|
2026-02-15 18:15:42 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
2026-02-17 01:39:59 +08:00
|
|
|
|
|
2026-02-15 18:15:42 +08:00
|
|
|
|
<!-- 右侧:引用类型 -->
|
2026-02-17 01:39:59 +08:00
|
|
|
|
<div class="compare-box">
|
|
|
|
|
|
<div class="box-header orange">引用类型(复制地址)</div>
|
|
|
|
|
|
|
|
|
|
|
|
<div class="memory-area">
|
|
|
|
|
|
<div class="vars-row">
|
|
|
|
|
|
<div class="var-item" :class="{ active: refStep >= 0 }">
|
|
|
|
|
|
<span class="var-label">obj1</span>
|
|
|
|
|
|
<span class="var-addr">0x001</span>
|
2026-02-15 18:15:42 +08:00
|
|
|
|
</div>
|
2026-02-17 01:39:59 +08:00
|
|
|
|
<div class="var-item" :class="{ active: refStep >= 1 }">
|
|
|
|
|
|
<span class="var-label">obj2</span>
|
|
|
|
|
|
<span class="var-addr">{{ refStep >= 1 ? '0x001' : '?' }}</span>
|
2026-02-15 18:15:42 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
2026-02-17 01:39:59 +08:00
|
|
|
|
<div class="data-box" :class="{ changed: refStep === 2, copied: refStep === 3 }">
|
|
|
|
|
|
<div class="data-addr">0x001</div>
|
|
|
|
|
|
<div class="data-content">{ age: {{ objData.age }} }</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="copy-arrow" v-if="refStep >= 1">指向同一地址</div>
|
2026-02-15 18:15:42 +08:00
|
|
|
|
</div>
|
2026-02-17 01:39:59 +08:00
|
|
|
|
|
|
|
|
|
|
<div class="result-text" :class="refStep === 2 ? 'warning' : refStep === 3 ? 'success' : 'info'">
|
|
|
|
|
|
{{ refStep === 0 ? '点击复制' : refStep === 1 ? '共享地址' : refStep === 2 ? '⚠️ 一改全变' : '✅ 已分离' }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<div class="btn-group">
|
|
|
|
|
|
<button @click="refCopy" :disabled="refStep >= 1">复制</button>
|
|
|
|
|
|
<button @click="refModify" :disabled="refStep !== 1">修改</button>
|
|
|
|
|
|
<button @click="refSpread" :disabled="refStep !== 2">展开</button>
|
|
|
|
|
|
<button @click="refReset" class="reset">重置</button>
|
2026-02-15 18:15:42 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
2026-02-17 01:39:59 +08:00
|
|
|
|
|
|
|
|
|
|
<div class="code-compare">
|
|
|
|
|
|
<div class="code-col">
|
|
|
|
|
|
<div class="code-title">基本类型</div>
|
|
|
|
|
|
<pre><code>let a = 10
|
|
|
|
|
|
let b = a // b=10
|
|
|
|
|
|
b = 20 // a还是10</code></pre>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="code-col">
|
|
|
|
|
|
<div class="code-title">引用类型</div>
|
|
|
|
|
|
<pre><code>let obj1 = {age:25}
|
|
|
|
|
|
let obj2 = obj1
|
|
|
|
|
|
obj2.age=30 // obj1也变了!
|
|
|
|
|
|
// 用 {...obj1} 复制</code></pre>
|
|
|
|
|
|
</div>
|
2026-02-15 18:15:42 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<style scoped>
|
|
|
|
|
|
.reference-demo {
|
|
|
|
|
|
border: 1px solid var(--vp-c-border);
|
|
|
|
|
|
border-radius: 12px;
|
2026-02-17 01:39:59 +08:00
|
|
|
|
padding: 20px;
|
|
|
|
|
|
margin: 16px 0;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
background: var(--vp-c-bg);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.demo-title {
|
|
|
|
|
|
font-size: 16px;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
font-weight: 600;
|
|
|
|
|
|
color: var(--vp-c-text-1);
|
2026-02-17 01:39:59 +08:00
|
|
|
|
margin-bottom: 16px;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.compare-grid {
|
2026-02-15 18:15:42 +08:00
|
|
|
|
display: grid;
|
|
|
|
|
|
grid-template-columns: 1fr 1fr;
|
2026-02-17 01:39:59 +08:00
|
|
|
|
gap: 16px;
|
|
|
|
|
|
margin-bottom: 16px;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@media (max-width: 768px) {
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.compare-grid {
|
2026-02-15 18:15:42 +08:00
|
|
|
|
grid-template-columns: 1fr;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.compare-box {
|
|
|
|
|
|
border: 1px solid var(--vp-c-border);
|
|
|
|
|
|
border-radius: 10px;
|
|
|
|
|
|
padding: 16px;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
background: var(--vp-c-bg-soft);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.box-header {
|
|
|
|
|
|
font-size: 13px;
|
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
|
padding: 6px 10px;
|
|
|
|
|
|
border-radius: 6px;
|
|
|
|
|
|
margin-bottom: 12px;
|
|
|
|
|
|
color: white;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.box-header.blue {
|
|
|
|
|
|
background: #3b82f6;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.box-header.orange {
|
|
|
|
|
|
background: #f59e0b;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.memory-area {
|
|
|
|
|
|
background: var(--vp-c-bg);
|
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
|
padding: 12px;
|
|
|
|
|
|
margin-bottom: 12px;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.vars-row {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
gap: 12px;
|
|
|
|
|
|
justify-content: center;
|
|
|
|
|
|
margin-bottom: 8px;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.var-item {
|
2026-02-15 18:15:42 +08:00
|
|
|
|
display: flex;
|
2026-02-17 01:39:59 +08:00
|
|
|
|
flex-direction: column;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
align-items: center;
|
2026-02-17 01:39:59 +08:00
|
|
|
|
padding: 8px 16px;
|
|
|
|
|
|
border: 2px solid var(--vp-c-border);
|
|
|
|
|
|
border-radius: 6px;
|
|
|
|
|
|
opacity: 0.4;
|
|
|
|
|
|
transition: all 0.3s;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.var-item.active {
|
|
|
|
|
|
opacity: 1;
|
|
|
|
|
|
border-color: #3b82f6;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.var-item.changed {
|
|
|
|
|
|
border-color: #10b981;
|
|
|
|
|
|
background: #ecfdf5;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.var-label {
|
|
|
|
|
|
font-size: 11px;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
color: var(--vp-c-text-2);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.var-val, .var-addr {
|
|
|
|
|
|
font-size: 18px;
|
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
|
font-family: monospace;
|
|
|
|
|
|
color: #3b82f6;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.var-addr {
|
|
|
|
|
|
color: #8b5cf6;
|
|
|
|
|
|
font-size: 14px;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.copy-arrow {
|
2026-02-15 18:15:42 +08:00
|
|
|
|
text-align: center;
|
2026-02-17 01:39:59 +08:00
|
|
|
|
font-size: 11px;
|
|
|
|
|
|
color: var(--vp-c-text-2);
|
|
|
|
|
|
padding: 4px;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.data-box {
|
|
|
|
|
|
border: 2px solid #8b5cf6;
|
|
|
|
|
|
border-radius: 6px;
|
|
|
|
|
|
padding: 8px;
|
|
|
|
|
|
text-align: center;
|
|
|
|
|
|
background: #f3e8ff;
|
|
|
|
|
|
margin-top: 8px;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.data-box.changed {
|
|
|
|
|
|
border-color: #ef4444;
|
|
|
|
|
|
background: #fee2e2;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.data-box.copied {
|
|
|
|
|
|
border-color: #10b981;
|
|
|
|
|
|
background: #d1fae5;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.data-addr {
|
|
|
|
|
|
font-size: 10px;
|
|
|
|
|
|
color: #6b7280;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.data-content {
|
|
|
|
|
|
font-family: monospace;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
font-size: 13px;
|
2026-02-17 01:39:59 +08:00
|
|
|
|
color: #374151;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.result-text {
|
|
|
|
|
|
text-align: center;
|
|
|
|
|
|
padding: 8px;
|
|
|
|
|
|
border-radius: 6px;
|
|
|
|
|
|
font-size: 12px;
|
|
|
|
|
|
margin-bottom: 12px;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.result-text.info {
|
|
|
|
|
|
background: #f3f4f6;
|
|
|
|
|
|
color: #4b5563;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.result-text.success {
|
|
|
|
|
|
background: #d1fae5;
|
|
|
|
|
|
color: #065f46;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.result-text.warning {
|
|
|
|
|
|
background: #fee2e2;
|
|
|
|
|
|
color: #991b1b;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.btn-group {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
gap: 6px;
|
|
|
|
|
|
flex-wrap: wrap;
|
|
|
|
|
|
justify-content: center;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.btn-group button {
|
|
|
|
|
|
padding: 6px 12px;
|
|
|
|
|
|
border: none;
|
|
|
|
|
|
border-radius: 4px;
|
|
|
|
|
|
font-size: 12px;
|
|
|
|
|
|
cursor: pointer;
|
|
|
|
|
|
background: #3b82f6;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
color: white;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.btn-group button:disabled {
|
|
|
|
|
|
opacity: 0.4;
|
|
|
|
|
|
cursor: not-allowed;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.btn-group button.reset {
|
|
|
|
|
|
background: var(--vp-c-bg-alt);
|
|
|
|
|
|
color: var(--vp-c-text-1);
|
|
|
|
|
|
border: 1px solid var(--vp-c-border);
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.code-compare {
|
|
|
|
|
|
display: grid;
|
|
|
|
|
|
grid-template-columns: 1fr 1fr;
|
|
|
|
|
|
gap: 12px;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.code-col {
|
2026-02-15 18:15:42 +08:00
|
|
|
|
background: #1e1e1e;
|
|
|
|
|
|
border-radius: 8px;
|
2026-02-17 01:39:59 +08:00
|
|
|
|
padding: 12px;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.code-title {
|
|
|
|
|
|
color: #9ca3af;
|
|
|
|
|
|
font-size: 11px;
|
|
|
|
|
|
margin-bottom: 8px;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.code-col pre {
|
2026-02-15 18:15:42 +08:00
|
|
|
|
margin: 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-17 01:39:59 +08:00
|
|
|
|
.code-col code {
|
|
|
|
|
|
font-family: monospace;
|
|
|
|
|
|
font-size: 11px;
|
|
|
|
|
|
line-height: 1.5;
|
2026-02-15 18:15:42 +08:00
|
|
|
|
color: #d4d4d4;
|
|
|
|
|
|
}
|
|
|
|
|
|
</style>
|