{"id":9047,"date":"2025-03-17T09:49:54","date_gmt":"2025-03-17T01:49:54","guid":{"rendered":"https:\/\/xinliceyan.org\/?p=9047"},"modified":"2025-05-25T17:22:18","modified_gmt":"2025-05-25T09:22:18","slug":"self-confidence","status":"publish","type":"post","link":"https:\/\/xinliceyan.org\/zh\/self-confidence","title":{"rendered":"\u81ea\u4fe1\u529b\u7ebf\u4e0a\u514d\u8d39\u6d4b\u9a8c\uff0840\u9898\uff09"},"content":{"rendered":"<!-- \u7eaf Bootstrap 5.3.3 \u7248\u672c\u81ea\u4fe1\u5fc3\u8a55\u4f30\u6e2c\u9a57\u7cfb\u7d71 -->\n<link href=\"https:\/\/cdnjs.cloudflare.com\/ajax\/libs\/bootstrap\/5.3.3\/css\/bootstrap.min.css\" rel=\"stylesheet\">\n<link href=\"https:\/\/cdnjs.cloudflare.com\/ajax\/libs\/bootstrap-icons\/1.11.3\/font\/bootstrap-icons.min.css\" rel=\"stylesheet\">\n\n<div class=\"cq-quiz-wrapper\" data-quiz=\"confidence-assessment\">\n  <!-- \u5f15\u5c0e\u9801 -->\n  <section class=\"cq-welcome-page\" data-page=\"welcome\">\n    <div class=\"container\">\n      <div class=\"row justify-content-center\">\n        <div class=\"col-lg-10 col-xl-8\">\n          \n          <!-- \u982d\u90e8\u5340\u57df -->\n          <header class=\"text-center mb-5 position-relative\">\n            <div class=\"cq-floating-icons position-absolute w-100\" style=\"top: -60px; height: 80px;\">\n              <div class=\"cq-icon position-absolute start-0 cq-float-1\">\n                <i class=\"bi bi-stars fs-1 text-warning\"><\/i>\n              <\/div>\n              <div class=\"cq-icon position-absolute start-50 translate-middle-x cq-float-2\">\n                <i class=\"bi bi-bullseye fs-1 text-primary\"><\/i>\n              <\/div>\n              <div class=\"cq-icon position-absolute end-0 cq-float-3\">\n                <i class=\"bi bi-lightning-charge fs-1 text-success\"><\/i>\n              <\/div>\n            <\/div>\n            \n            <h2 class=\"display-4 fw-bold mb-3 text-primary\">\u81ea\u4fe1\u5fc3\u8a55\u4f30\u6e2c\u9a57<\/h2>\n            <p class=\"lead text-muted mb-0\">\u63a2\u7d22\u4f60\u7684\u5167\u5728\u529b\u91cf\uff0c\u767c\u73fe\u771f\u5be6\u7684\u81ea\u5df1<\/p>\n          <\/header>\n\n          <!-- \u7279\u8272\u4ecb\u7d39 -->\n          <div class=\"row g-4 mb-5\">\n            <div class=\"col-md-4\">\n              <div class=\"card h-100 border-0 shadow-sm cq-feature-card\">\n                <div class=\"card-body text-center p-4\">\n                  <div class=\"mb-3\">\n                    <i class=\"bi bi-graph-up-arrow fs-1 text-primary\"><\/i>\n                  <\/div>\n                  <h5 class=\"card-title fw-bold\">\u79d1\u5b66\u8bc4\u4f30<\/h5>\n                  <p class=\"card-text text-muted\">\u57fa\u65bc\u5fc3\u7406\u5b78\u7406\u8ad6\u8a2d\u8a08\u7684\u5c08\u696d\u6e2c\u9a57\uff0c\u6e96\u78ba\u8a55\u4f30\u60a8\u7684\u81ea\u4fe1\u6c34\u5e73<\/p>\n                <\/div>\n              <\/div>\n            <\/div>\n            \n            <div class=\"col-md-4\">\n              <div class=\"card h-100 border-0 shadow-sm cq-feature-card\">\n                <div class=\"card-body text-center p-4\">\n                  <div class=\"mb-3\">\n                    <i class=\"bi bi-clock fs-1 text-success\"><\/i>\n                  <\/div>\n                  <h5 class=\"card-title fw-bold\">\u5feb\u901f\u4fbf\u6377<\/h5>\n                  <p class=\"card-text text-muted\">\u50c5\u97005-8\u5206\u9418\uff0c40\u9053\u7cbe\u5fc3\u8a2d\u8a08\u7684\u984c\u76ee\uff0c\u7c21\u55ae\u662f\u975e\u9078\u64c7<\/p>\n                <\/div>\n              <\/div>\n            <\/div>\n            \n            <div class=\"col-md-4\">\n              <div class=\"card h-100 border-0 shadow-sm cq-feature-card\">\n                <div class=\"card-body text-center p-4\">\n                  <div class=\"mb-3\">\n                    <i class=\"bi bi-pie-chart fs-1 text-info\"><\/i>\n                  <\/div>\n                  <h5 class=\"card-title fw-bold\">\u89c6\u89c9\u5316\u7ed3\u679c<\/h5>\n                  <p class=\"card-text text-muted\">\u76f4\u89c0\u7684\u5716\u8868\u5206\u6790\uff0c\u6df1\u5ea6\u89e3\u8b80\u60a8\u7684\u81ea\u4fe1\u5fc3\u7d50\u69cb<\/p>\n                <\/div>\n              <\/div>\n            <\/div>\n          <\/div>\n\n          <!-- \u6e2c\u9a57\u8aaa\u660e -->\n          <div class=\"card border-0 shadow-sm mb-5 bg-light\">\n            <div class=\"card-body p-4\">\n              <div class=\"row align-items-center\">\n                <div class=\"col-lg-8\">\n                  <p class=\"mb-3 fs-6\">\u6b61\u8fce\u53c3\u52a0\u81ea\u4fe1\u5fc3\u8a55\u4f30\uff01\u672c\u6e2c\u8a66\u900f\u904e\u65e5\u5e38\u884c\u70ba\u8207\u5fc3\u7406\u72c0\u614b\u8a55\u4f30\u60a8\u7684\u81ea\u4fe1\u6c34\u5e73\u3002\u8acb\u6839\u64da\u7b2c\u4e00\u53cd\u61c9\u5982\u5be6\u4f5c\u7b54\uff0c\u9078\u64c7\u300c\u662f\u300d\u6216\u300c\u5426\u300d\uff0c\u7121\u9700\u904e\u591a\u601d\u8003\u3002<\/p>\n                  <p class=\"mb-3 fs-6\">\u6240\u6709\u554f\u984c\u7121\u5c0d\u932f\u4e4b\u5206\uff0c\u6e2c\u8a66\u7d50\u679c\u50c5\u4f5c\u81ea\u6211\u8a8d\u77e5\u53c3\u8003\u3002\u5efa\u8b70\u5728\u5b89\u975c\u74b0\u5883\u5b8c\u6210\u3002<\/p>\n                  <div class=\"alert alert-warning border-0 mb-0\" role=\"alert\">\n                    <i class=\"bi bi-exclamation-triangle me-2\"><\/i>\n                    <strong>\u6ce8\u610f\uff1a<\/strong>\u672c\u91cf\u8868\u5c6c\u81ea\u8a55\u5de5\u5177\uff0c\u4e0d\u80fd\u66ff\u4ee3\u5c08\u696d\u5fc3\u7406\u8a55\u4f30\u3002\u60a8\u7684\u771f\u5be6\u56de\u7b54\u5c07\u76f4\u63a5\u5f71\u97ff\u7d50\u679c\u6e96\u78ba\u6027\u3002\n                  <\/div>\n                <\/div>\n                <div class=\"col-lg-4 text-center\">\n                  <i class=\"bi bi-person-check fs-1 text-primary mb-3 d-block\"><\/i>\n                  <div class=\"badge bg-primary fs-6 px-3 py-2\">40\u984c\u8a55\u4f30<\/div>\n                <\/div>\n              <\/div>\n            <\/div>\n          <\/div>\n\n          <!-- \u958b\u59cb\u6309\u9215 -->\n          <div class=\"text-center\">\n            <button class=\"btn btn-primary btn-lg px-5 py-3 cq-start-btn\" data-action=\"start-quiz\">\n              <i class=\"bi bi-play-circle me-2\"><\/i>\n              <span>\u5f00\u59cb\u6d4b\u9a8c<\/span>\n            <\/button>\n          <\/div>\n\n        <\/div>\n      <\/div>\n    <\/div>\n  <\/section>\n\n  <!-- \u6e2c\u9a57\u9801 -->\n  <section class=\"cq-quiz-page d-none\" data-page=\"quiz\">\n    <div class=\"container\">\n      <div class=\"row justify-content-center\">\n        <div class=\"col-lg-8\">\n          \n          <!-- \u6e2c\u9a57\u6a19\u984c\u548c\u9032\u5ea6 -->\n          <header class=\"text-center mb-4\">\n            <h2 class=\"h3 fw-bold mb-4 text-primary\">\u81ea\u4fe1\u5fc3\u8a55\u4f30<\/h2>\n            \n            <div class=\"cq-progress-container\">\n              <div class=\"d-flex justify-content-between align-items-center mb-2\">\n                <span class=\"badge bg-secondary\">\u9898\u76ee\u8fdb\u5ea6<\/span>\n                <span class=\"fw-semibold text-muted\">\n                  <span class=\"cq-current-question\">1<\/span> \/ <span class=\"cq-total-questions\">40<\/span>\n                <\/span>\n              <\/div>\n              <div class=\"progress\" style=\"height: 8px;\">\n                <div class=\"progress-bar cq-progress-fill\" role=\"progressbar\" style=\"width: 2.5%\"><\/div>\n              <\/div>\n            <\/div>\n          <\/header>\n\n          <!-- \u554f\u984c\u5361\u7247 -->\n          <div class=\"card border-0 shadow-sm mb-4 cq-question-card\">\n            <div class=\"card-body p-4 p-md-5\">\n              <h3 class=\"h5 fw-bold mb-4 cq-question-text\" data-question-text style=\"font-size: 22px; line-height: 1.4;\"><\/h3>\n              \n              <div class=\"d-grid gap-3\">\n                <button class=\"btn btn-outline-success btn-lg d-flex align-items-center cq-option-btn\" data-option=\"yes\" data-value=\"1\">\n                  <i class=\"bi bi-check-circle me-3 fs-4\"><\/i>\n                  <span class=\"fs-5 fw-semibold\">\u662f<\/span>\n                <\/button>\n                \n                <button class=\"btn btn-outline-danger btn-lg d-flex align-items-center cq-option-btn\" data-option=\"no\" data-value=\"0\">\n                  <i class=\"bi bi-x-circle me-3 fs-4\"><\/i>\n                  <span class=\"fs-5 fw-semibold\">\u5426<\/span>\n                <\/button>\n              <\/div>\n            <\/div>\n          <\/div>\n\n          <!-- \u5c0e\u822a\u6309\u9215 -->\n          <div class=\"text-center\">\n            <button class=\"btn btn-outline-secondary d-none cq-prev-btn\" data-action=\"prev-question\">\n              <i class=\"bi bi-arrow-left me-2\"><\/i>\u4e0a\u4e00\u9898\n            <\/button>\n          <\/div>\n\n        <\/div>\n      <\/div>\n    <\/div>\n  <\/section>\n\n  <!-- \u7d50\u679c\u9801 -->\n  <section class=\"cq-result-page d-none\" data-page=\"result\">\n    <div class=\"container\">\n      <div class=\"row justify-content-center\">\n        <div class=\"col-lg-10\">\n          \n          <!-- \u7d50\u679c\u6a19\u984c\u548c\u7e3d\u5206 -->\n          <header class=\"text-center mb-5\">\n            <h2 class=\"h3 fw-bold mb-4 text-primary\">\u6d4b\u9a8c\u7ed3\u679c<\/h2>\n            <div class=\"row justify-content-center\">\n              <div class=\"col-md-6 col-lg-4\">\n                <div class=\"card border-0 shadow bg-primary text-white\">\n                  <div class=\"card-body text-center p-4\">\n                    <div class=\"display-3 fw-bold mb-2 cq-score-display\" data-score-display><\/div>\n                    <div class=\"fs-5 opacity-75\">\u603b\u5206<\/div>\n                  <\/div>\n                <\/div>\n              <\/div>\n            <\/div>\n          <\/header>\n\n          <!-- \u5716\u8868\u5340\u57df -->\n          <div class=\"card border-0 shadow-sm mb-5\">\n            <div class=\"card-body p-4\">\n              <h5 class=\"card-title text-center mb-4 fw-bold\">\u5404\u7dad\u5ea6\u8868\u73fe\u5206\u6790<\/h5>\n              <div class=\"cq-chart-container\">\n                <div class=\"cq-chart-wrapper\">\n                  <canvas id=\"cq-confidence-chart\"><\/canvas>\n                <\/div>\n              <\/div>\n            <\/div>\n          <\/div>\n\n          <!-- \u8a73\u7d30\u5206\u6790 -->\n          <div class=\"card border-0 shadow-sm mb-4\">\n            <div class=\"card-body p-4\">\n              <h5 class=\"card-title text-center mb-4 fw-bold\">\n                <i class=\"bi bi-clipboard-data me-2\"><\/i>\u8be6\u7ec6\u5206\u6790\n              <\/h5>\n              <div class=\"cq-analysis-content\" data-analysis-content><\/div>\n            <\/div>\n          <\/div>\n\n          <!-- \u7dad\u5ea6\u5f97\u5206 -->\n          <div class=\"mb-5\">\n            <h5 class=\"text-center mb-4 fw-bold\">\u5404\u7dad\u5ea6\u8868\u73fe<\/h5>\n            <div class=\"row g-3 cq-dimensions-grid\" data-dimensions-grid><\/div>\n          <\/div>\n\n          <!-- \u91cd\u65b0\u6e2c\u9a57\u6309\u9215 -->\n          <div class=\"text-center\">\n            <button class=\"btn btn-success btn-lg px-5 py-3\" data-action=\"restart-quiz\">\n              <i class=\"bi bi-arrow-clockwise me-2\"><\/i>\n              \u91cd\u65b0\u6d4b\u9a8c\n            <\/button>\n          <\/div>\n\n        <\/div>\n      <\/div>\n    <\/div>\n  <\/section>\n<\/div>\n\n<style>\n\/* \u7d14 Bootstrap \u6837\u5f0f\u88dc\u5145 - \u4e0d\u4f7f\u7528\u81ea\u5b9a\u7fa9\u8b8a\u91cf *\/\n.cq-quiz-wrapper {\n  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;\n  padding: 2rem 0;\n}\n\n\/* \u6d6e\u52d5\u52d5\u756b *\/\n@keyframes cqFloat1 {\n  0%, 100% { transform: translateY(0px) rotate(0deg); }\n  50% { transform: translateY(-15px) rotate(5deg); }\n}\n\n@keyframes cqFloat2 {\n  0%, 100% { transform: translateY(0px) rotate(0deg); }\n  50% { transform: translateY(-20px) rotate(-3deg); }\n}\n\n@keyframes cqFloat3 {\n  0%, 100% { transform: translateY(0px) rotate(0deg); }\n  50% { transform: translateY(-12px) rotate(8deg); }\n}\n\n.cq-float-1 { animation: cqFloat1 6s ease-in-out infinite; }\n.cq-float-2 { animation: cqFloat2 6s ease-in-out infinite 2s; }\n.cq-float-3 { animation: cqFloat3 6s ease-in-out infinite 4s; }\n\n\/* \u5361\u7247\u61f8\u505c\u6548\u679c *\/\n.cq-feature-card {\n  transition: all 0.3s ease;\n}\n\n.cq-feature-card:hover {\n  transform: translateY(-8px);\n  box-shadow: 0 1rem 3rem rgba(0,0,0,0.15) !important;\n}\n\n\/* \u958b\u59cb\u6309\u9215\u7279\u6b8a\u6548\u679c *\/\n.cq-start-btn {\n  transition: all 0.3s ease;\n  position: relative;\n  overflow: hidden;\n}\n\n.cq-start-btn:hover {\n  transform: translateY(-3px);\n  box-shadow: 0 1rem 2rem rgba(13, 110, 253, 0.3) !important;\n}\n\n.cq-start-btn:active {\n  transform: translateY(-1px);\n}\n\n.cq-start-btn::before {\n  content: '';\n  position: absolute;\n  top: 0;\n  left: -100%;\n  width: 100%;\n  height: 100%;\n  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);\n  transition: left 0.5s ease;\n}\n\n.cq-start-btn:hover::before {\n  left: 100%;\n}\n\n\/* \u554f\u984c\u5361\u7247 *\/\n.cq-question-card {\n  background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);\n}\n\n\/* \u9078\u9805\u6309\u9215\u81ea\u5b9a\u7fa9 *\/\n.cq-option-btn {\n  min-height: 60px;\n  font-size: 18px;\n  transition: all 0.3s ease;\n  border-width: 2px !important;\n}\n\n.cq-option-btn:hover {\n  transform: translateX(8px);\n  box-shadow: 0 0.5rem 1rem rgba(0,0,0,0.1);\n}\n\n.cq-option-btn.cq-selected {\n  transform: translateX(8px);\n  box-shadow: 0 0.5rem 1rem rgba(0,0,0,0.2);\n}\n\n\/* \u6210\u529f\u9078\u9805\u9078\u4e2d\u72c0\u614b *\/\n.cq-option-btn[data-option=\"yes\"].cq-selected {\n  background-color: #198754 !important;\n  border-color: #198754 !important;\n  color: white !important;\n}\n\n.cq-option-btn[data-option=\"yes\"].cq-selected i {\n  color: white !important;\n}\n\n\/* \u5371\u96aa\u9078\u9805\u9078\u4e2d\u72c0\u614b *\/\n.cq-option-btn[data-option=\"no\"].cq-selected {\n  background-color: #dc3545 !important;\n  border-color: #dc3545 !important;\n  color: white !important;\n}\n\n.cq-option-btn[data-option=\"no\"].cq-selected i {\n  color: white !important;\n}\n\n\/* \u9032\u5ea6\u689d *\/\n.cq-progress-fill {\n  transition: width 0.5s ease;\n}\n\n\/* \u7dad\u5ea6\u9805\u76ee *\/\n.cq-dimension-item {\n  background: white;\n  border: 1px solid rgba(0,0,0,0.05);\n  border-radius: 0.5rem;\n  padding: 1.5rem;\n  text-align: center;\n  transition: all 0.3s ease;\n  box-shadow: 0 0.25rem 0.5rem rgba(0,0,0,0.05);\n}\n\n.cq-dimension-item:hover {\n  transform: translateY(-4px);\n  box-shadow: 0 0.5rem 1rem rgba(0,0,0,0.1);\n}\n\n.cq-dimension-name {\n  font-size: 1rem;\n  font-weight: 600;\n  color: #6c757d;\n  margin-bottom: 0.5rem;\n}\n\n.cq-dimension-score {\n  font-size: 1.5rem;\n  font-weight: 700;\n  color: #0d6efd;\n}\n\n\/* \u5716\u8868\u5bb9\u5668 *\/\n.cq-chart-container {\n  width: 100%;\n  position: relative;\n}\n\n.cq-chart-wrapper {\n  position: relative;\n  width: 100%;\n  height: 0;\n  padding-bottom: 60%; \/* \u7ef4\u630116:9.6\u7684\u5bbd\u9ad8\u6bd4 *\/\n  min-height: 300px;\n}\n\n.cq-chart-wrapper canvas {\n  position: absolute !important;\n  top: 0;\n  left: 0;\n  width: 100% !important;\n  height: 100% !important;\n}\n\n\/* \u79fb\u52a8\u8bbe\u5907\u4e0a\u7684\u56fe\u8868\u4f18\u5316 *\/\n@media (max-width: 768px) {\n  .cq-chart-wrapper {\n    padding-bottom: 80%; \/* \u79fb\u52a8\u8bbe\u5907\u4e0a\u66f4\u9ad8\u7684\u6bd4\u4f8b *\/\n    min-height: 280px;\n  }\n}\n\n@media (max-width: 576px) {\n  .cq-chart-wrapper {\n    padding-bottom: 100%; \/* \u5c0f\u5c4f\u5e55\u4e0a\u63a5\u8fd1\u6b63\u65b9\u5f62 *\/\n    min-height: 250px;\n  }\n}\n\n\/* \u97ff\u61c9\u5f0f\u8abf\u6574 *\/\n@media (max-width: 768px) {\n  .cq-quiz-wrapper {\n    padding: 1rem 0;\n  }\n  \n  .cq-floating-icons {\n    display: none;\n  }\n  \n  .cq-option-btn {\n    min-height: 56px;\n    font-size: 16px;\n  }\n  \n  .cq-option-btn:hover {\n    transform: none;\n  }\n  \n  .cq-question-text {\n    font-size: 20px !important;\n  }\n}\n\n@media (max-width: 576px) {\n  .cq-question-text {\n    font-size: 18px !important;\n  }\n  \n  .cq-option-btn {\n    font-size: 16px;\n  }\n}\n\n\/* \u53ef\u8a2a\u554f\u6027\u512a\u5316 *\/\n@media (prefers-reduced-motion: reduce) {\n  .cq-float-1, .cq-float-2, .cq-float-3 {\n    animation: none;\n  }\n  \n  .cq-feature-card,\n  .cq-start-btn,\n  .cq-option-btn,\n  .cq-dimension-item {\n    transition: none;\n  }\n}\n\n\/* \u7126\u9ede\u72c0\u614b\u4f7f\u7528Bootstrap\u9ed8\u8a8d\u984f\u8272 *\/\n.cq-start-btn:focus,\n.cq-option-btn:focus {\n  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);\n}\n\n\/* \u9ad8\u5c0d\u6bd4\u5ea6\u6a21\u5f0f\u652f\u63f4 *\/\n@media (prefers-contrast: high) {\n  .card {\n    border: 2px solid #6c757d !important;\n  }\n  \n  .btn {\n    border-width: 2px !important;\n  }\n}\n<\/style>\n\n<script src=\"https:\/\/cdnjs.cloudflare.com\/ajax\/libs\/Chart.js\/4.4.1\/chart.umd.min.js\"><\/script>\n\n<script>\n\/\/ \u7d14 Bootstrap \u7248\u672c\u81ea\u4fe1\u5fc3\u8a55\u4f30\u6e2c\u9a57\u7cfb\u7d71\n(function() {\n  'use strict';\n  \n  \/\/ \u914d\u7f6e\u5e38\u91cf - \u4f7f\u7528Bootstrap\u9ed8\u8a8d\u984f\u8272\n  const CONFIG = {\n    ANIMATION_DURATION: 300,\n    SCROLL_BEHAVIOR: 'smooth',\n    CHART_COLORS: {\n      primary: '#0d6efd',    \/\/ Bootstrap primary\n      secondary: '#6c757d',  \/\/ Bootstrap secondary  \n      success: '#198754',    \/\/ Bootstrap success\n      info: '#0dcaf0',       \/\/ Bootstrap info\n      warning: '#ffc107',    \/\/ Bootstrap warning\n      danger: '#dc3545'      \/\/ Bootstrap danger\n    }\n  };\n\n  \/\/ \u6e2c\u9a57\u6578\u64da\n  const QUIZ_DATA = {\n    questions: [\n      { text: \"\u4e00\u65e6\u4f60\u4e0b\u4e86\u6c7a\u5fc3\uff0c\u5373\u4f7f\u6c92\u6709\u4eba\u8d0a\u540c\uff0c\u4f60\u4ecd\u6703\u5805\u6301\u505a\u5230\u5e95\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u53c3\u52a0\u665a\u5bb4\u6642\uff0c\u5373\u4f7f\u5f88\u60f3\u4e0a\u6d17\u624b\u9593\uff0c\u4f60\u4e5f\u6703\u5fcd\u8457\u76f4\u5230\u5bb4\u6703\u7d50\u675f\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u5982\u679c\u60f3\u8cb7\u6027\u611f\u5167\u8863\uff0c\u4f60\u6703\u76e1\u91cf\u90f5\u8cfc\uff0c\u800c\u4e0d\u89aa\u81ea\u5230\u5e97\u88e1\u53bb\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u4f60\u8a8d\u70ba\u81ea\u5df1\u662f\u500b\u8f03\u5b8c\u7f8e\u7684\u4eba\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u5982\u679c\u5e97\u54e1\u7684\u670d\u52d9\u614b\u5ea6\u4e0d\u597d\uff0c\u4f60\u6703\u544a\u8a34\u4ed6\u5011\u7684\u7d93\u7406\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u4f60\u4e0d\u5e38\u6b23\u8cde\u81ea\u5df1\u7684\u7167\u7247\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u5225\u4eba\u6279\u8a55\u4f60\uff0c\u4f60\u6703\u89ba\u5f97\u96e3\u904e\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u4f60\u5f88\u5c11\u5c0d\u4eba\u8aaa\u51fa\u4f60\u771f\u6b63\u7684\u610f\u898b\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u5c0d\u5225\u4eba\u7684\u8b9a\u7f8e\uff0c\u4f60\u6301\u61f7\u7591\u7684\u614b\u5ea6\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u4f60\u7e3d\u662f\u89ba\u5f97\u81ea\u5df1\u6bd4\u5225\u4eba\u5dee\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u4f60\u5c0d\u81ea\u5df1\u7684\u5916\u8868\u6eff\u610f\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u4f60\u8a8d\u70ba\u81ea\u5df1\u7684\u80fd\u529b\u6bd4\u5225\u4eba\u5dee\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u5728\u805a\u6703\u4e0a\uff0c\u53ea\u6709\u4f60\u4e00\u500b\u4eba\u7a7f\u5f97\u4e0d\u6b63\u5f0f\uff0c\u4f60\u6703\u611f\u5230\u4e0d\u81ea\u5728\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u4f60\u662f\u500b\u53d7\u6b61\u8fce\u7684\u4eba\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u4f60\u8a8d\u70ba\u81ea\u5df1\u5f88\u6709\u9b45\u529b\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u4f60\u6709\u5e7d\u9ed8\u611f\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u76ee\u524d\u7684\u5de5\u4f5c\u662f\u4f60\u7684\u5c08\u9577\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u4f60\u61c2\u5f97\u642d\u914d\u8863\u670d\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u5371\u6025\u6642\uff0c\u4f60\u5f88\u51b7\u975c\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u4f60\u8207\u5225\u4eba\u5408\u4f5c\u7121\u9593\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u4f60\u8a8d\u70ba\u81ea\u5df1\u53ea\u662f\u500b\u5c0b\u5e38\u4eba\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u4f60\u7d93\u5e38\u5e0c\u671b\u81ea\u5df1\u9577\u5f97\u50cf\u67d0\u67d0\u4eba\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u4f60\u7d93\u5e38\u7fa8\u6155\u5225\u4eba\u7684\u6210\u5c31\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u4f60\u70ba\u4e86\u4e0d\u4f7f\u4ed6\u4eba\u96e3\u904e\uff0c\u800c\u653e\u68c4\u81ea\u5df1\u559c\u6b61\u505a\u7684\u4e8b\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u4f60\u6703\u70ba\u4e86\u8a0e\u597d\u5225\u4eba\u800c\u6253\u626e\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u4f60\u52c9\u5f37\u81ea\u5df1\u505a\u8a31\u591a\u4e0d\u9858\u610f\u505a\u7684\u4e8b\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u4f60\u4efb\u7531\u4ed6\u4eba\u4f86\u652f\u914d\u4f60\u7684\u751f\u6d3b\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u4f60\u8a8d\u70ba\u4f60\u7684\u512a\u9ede\u6bd4\u7f3a\u9ede\u591a\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u4f60\u7d93\u5e38\u8ddf\u4eba\u8aaa\u62b1\u6b49\u55ce\uff1f\u5373\u4f7f\u5728\u4e0d\u662f\u4f60\u932f\u7684\u60c5\u6cc1\u4e0b\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u5982\u679c\u5728\u975e\u6545\u610f\u7684\u60c5\u6cc1\u4e0b\u50b7\u4e86\u5225\u4eba\u7684\u5fc3\uff0c\u4f60\u6703\u96e3\u904e\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u4f60\u5e0c\u671b\u81ea\u5df1\u5177\u5099\u66f4\u591a\u7684\u624d\u80fd\u548c\u5929\u8ce6\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u4f60\u7d93\u5e38\u807d\u53d6\u5225\u4eba\u7684\u610f\u898b\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u5728\u805a\u6703\u4e0a\uff0c\u4f60\u7d93\u5e38\u7b49\u5225\u4eba\u5148\u8ddf\u4f60\u6253\u62db\u547c\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u4f60\u6bcf\u5929\u7167\u93e1\u5b50\u8d85\u904e\u4e09\u6b21\u55ce\uff1f\", scoring: { yes: 0, no: 1 } },\n      { text: \"\u4f60\u7684\u500b\u6027\u5f88\u5f37\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u4f60\u662f\u500b\u512a\u79c0\u7684\u9818\u5c0e\u8005\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u4f60\u7684\u8a18\u6027\u5f88\u597d\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u4f60\u5c0d\u7570\u6027\u6709\u5438\u5f15\u529b\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u4f60\u61c2\u5f97\u7406\u8ca1\u55ce\uff1f\", scoring: { yes: 1, no: 0 } },\n      { text: \"\u8cb7\u8863\u670d\u524d\uff0c\u4f60\u901a\u5e38\u5148\u807d\u53d6\u5225\u4eba\u7684\u610f\u898b\u55ce\uff1f\", scoring: { yes: 0, no: 1 } }\n    ],\n    \n    interpretations: {\n      high: {\n        range: [25, 40],\n        title: \"\u9ad8\u81ea\u4fe1\u5fc3\",\n        description: \"\u8aaa\u660e\u4f60\u5c0d\u81ea\u5df1\u81ea\u4fe1\u5fc3\u5341\u8db3\uff0c\u660e\u767d\u81ea\u5df1\u7684\u512a\u9ede\uff0c\u540c\u6642\u4e5f\u6e05\u695a\u81ea\u5df1\u7684\u7f3a\u9ede\u3002\u4e0d\u904e\uff0c\u5728\u6b64\u8b66\u544a\u4f60\u4e00\u8072\uff1a\u5982\u679c\u4f60\u5f97\u5206\u5c07\u8fd140\u7684\u8a71\uff0c\u5225\u4eba\u53ef\u80fd\u6703\u8a8d\u70ba\u4f60\u5f88\u81ea\u5927\u72c2\u50b2\uff0c\u751a\u81f3\u6c23\u7130\u592a\u52dd\u3002\u4f60\u4e0d\u59a8\u5728\u5225\u4eba\u9762\u524d\u8b19\u865b\u4e00\u9ede\uff0c\u9019\u6a23\u4eba\u7de3\u624d\u6703\u597d\u3002\",\n        color: CONFIG.CHART_COLORS.success,\n        badgeClass: 'bg-success'\n      },\n      medium: {\n        range: [12, 24],\n        title: \"\u4e2d\u7b49\u81ea\u4fe1\u5fc3\",\n        description: \"\u8aaa\u660e\u4f60\u5c0d\u81ea\u5df1\u9817\u6709\u81ea\u4fe1\uff0c\u4f46\u662f\u4f60\u4ecd\u6216\u591a\u6216\u5c11\u7f3a\u4e4f\u5b89\u5168\u611f\uff0c\u5c0d\u81ea\u5df1\u7522\u751f\u61f7\u7591\u3002\u4f60\u4e0d\u59a8\u63d0\u9192\u81ea\u5df1\uff0c\u5728\u512a\u9ede\u548c\u9577\u8655\u5404\u65b9\u9762\u4e26\u4e0d\u8f38\u4eba\uff0c\u7279\u5225\u5f37\u8abf\u81ea\u5df1\u7684\u624d\u80fd\u548c\u6210\u5c31\u3002\",\n        color: CONFIG.CHART_COLORS.warning,\n        badgeClass: 'bg-warning'\n      },\n      low: {\n        range: [0, 11],\n        title: \"\u8f03\u4f4e\u81ea\u4fe1\u5fc3\",\n        description: \"\u8aaa\u660e\u4f60\u5c0d\u81ea\u5df1\u986f\u7136\u4e0d\u592a\u6709\u4fe1\u5fc3\u3002\u4f60\u904e\u65bc\u8b19\u865b\u548c\u81ea\u6211\u58d3\u6291\uff0c\u56e0\u6b64\u7d93\u5e38\u53d7\u4eba\u652f\u914d\u3002\u5f9e\u73fe\u5728\u8d77\uff0c\u5118\u7ba1\u4e0d\u8981\u53bb\u60f3\u81ea\u5df1\u7684\u5f31\u9ede\uff0c\u591a\u5f80\u597d\u7684\u4e00\u9762\u53bb\u8861\u91cf\uff1b\u5148\u5b78\u6703\u770b\u91cd\u81ea\u5df1\uff0c\u5225\u4eba\u624d\u6703\u771f\u6b63\u770b\u91cd\u4f60\u3002\",\n        color: CONFIG.CHART_COLORS.info,\n        badgeClass: 'bg-info'\n      }\n    }\n  };\n\n  \/\/ \u72c0\u614b\u7ba1\u7406\n  const state = {\n    currentQuestion: 0,\n    answers: [],\n    totalScore: 0,\n    currentPage: 'welcome'\n  };\n\n  \/\/ DOM \u5143\u7d20\u5feb\u53d6\n  const elements = {\n    container: null,\n    welcomePage: null,\n    quizPage: null,\n    resultPage: null,\n    questionText: null,\n    optionButtons: null,\n    progressInfo: null,\n    progressFill: null,\n    prevBtn: null,\n    scoreDisplay: null,\n    analysisContent: null,\n    dimensionsGrid: null\n  };\n\n  \/\/ \u5de5\u5177\u51fd\u6578\n  const utils = {\n    \/\/ \u5e73\u6ed1\u6efe\u52d5\u5230\u5143\u7d20\n    scrollToElement: (element, offset = 0) => {\n      if (!element) return;\n      const elementPosition = element.getBoundingClientRect().top + window.pageYOffset;\n      const offsetPosition = elementPosition + offset;\n      \n      window.scrollTo({\n        top: offsetPosition,\n        behavior: CONFIG.SCROLL_BEHAVIOR\n      });\n    },\n\n    \/\/ \u9632\u6296\u51fd\u6578\n    debounce: (func, wait) => {\n      let timeout;\n      return function executedFunction(...args) {\n        const later = () => {\n          clearTimeout(timeout);\n          func(...args);\n        };\n        clearTimeout(timeout);\n        timeout = setTimeout(later, wait);\n      };\n    },\n\n    \/\/ \u7372\u53d6\u5206\u6578\u89e3\u91cb\n    getScoreInterpretation: (score) => {\n      const { high, medium, low } = QUIZ_DATA.interpretations;\n      \n      if (score >= high.range[0] && score <= high.range[1]) return high;\n      if (score >= medium.range[0] && score <= medium.range[1]) return medium;\n      return low;\n    },\n\n    \/\/ \u8a08\u7b97\u7dad\u5ea6\u5206\u6578\n    calculateDimensions: (answers) => {\n      const dimensions = {\n        selfAcceptance: { name: '\u81ea\u6211\u63a5\u7d0d', questions: [0, 3, 5, 6, 10, 14, 27], score: 0 },\n        assertiveness: { name: '\u81ea\u6211\u4e3b\u5f35', questions: [1, 4, 7, 23, 24, 26, 34], score: 0 },\n        socialConfidence: { name: '\u793e\u4ea4\u81ea\u4fe1', questions: [2, 12, 13, 19, 32, 37], score: 0 },\n        selfEfficacy: { name: '\u81ea\u6211\u6548\u80fd', questions: [16, 17, 18, 35, 36, 38], score: 0 },\n        autonomy: { name: '\u81ea\u4e3b\u6027', questions: [8, 9, 11, 20, 21, 22, 25, 28, 29, 30, 31, 33, 39], score: 0 }\n      };\n\n      \/\/ \u8a08\u7b97\u5404\u7dad\u5ea6\u5206\u6578\n      Object.values(dimensions).forEach(dimension => {\n        const totalQuestions = dimension.questions.length;\n        const earnedPoints = dimension.questions.reduce((sum, qIndex) => {\n          return sum + (answers[qIndex] || 0);\n        }, 0);\n        dimension.score = Math.round((earnedPoints \/ totalQuestions) * 100);\n      });\n\n      return dimensions;\n    }\n  };\n\n  \/\/ \u9801\u9762\u7ba1\u7406\n  const pageManager = {\n    showPage: (pageName) => {\n      \/\/ \u6e05\u7406\u4e4b\u524d\u7684\u56fe\u8868\n      if (window.confidenceChart) {\n        window.confidenceChart.destroy();\n        window.confidenceChart = null;\n      }\n      \n      \/\/ \u96b1\u85cf\u6240\u6709\u9801\u9762\n      [elements.welcomePage, elements.quizPage, elements.resultPage].forEach(page => {\n        if (page) page.classList.add('d-none');\n      });\n\n      \/\/ \u986f\u793a\u76ee\u6a19\u9801\u9762\n      const targetPage = elements.container.querySelector(`[data-page=\"${pageName}\"]`);\n      if (targetPage) {\n        targetPage.classList.remove('d-none');\n        state.currentPage = pageName;\n        \n        \/\/ \u6efe\u52d5\u5230\u9801\u9762\u9802\u90e8\n        setTimeout(() => {\n          utils.scrollToElement(targetPage, -20);\n        }, 50);\n      }\n    },\n\n    updateProgress: () => {\n      const progress = ((state.currentQuestion + 1) \/ QUIZ_DATA.questions.length) * 100;\n      elements.progressFill.style.width = `${progress}%`;\n      elements.progressInfo.querySelector('.cq-current-question').textContent = state.currentQuestion + 1;\n    }\n  };\n\n  \/\/ \u6e2c\u9a57\u908f\u8f2f\n  const quizManager = {\n    startQuiz: () => {\n      state.currentQuestion = 0;\n      state.answers = [];\n      state.totalScore = 0;\n      \n      pageManager.showPage('quiz');\n      quizManager.displayQuestion();\n    },\n\n    displayQuestion: () => {\n      const question = QUIZ_DATA.questions[state.currentQuestion];\n      if (!question) return;\n\n      \/\/ \u66f4\u65b0\u554f\u984c\u6587\u672c\n      elements.questionText.textContent = question.text;\n      \n      \/\/ \u91cd\u7f6e\u9078\u9805\u72c0\u614b\n      elements.optionButtons.forEach(btn => {\n        btn.classList.remove('cq-selected');\n        \/\/ \u91cd\u7f6e\u70ba\u539f\u59cbBootstrap\u985e\n        if (btn.dataset.option === 'yes') {\n          btn.className = 'btn btn-outline-success btn-lg d-flex align-items-center cq-option-btn';\n        } else {\n          btn.className = 'btn btn-outline-danger btn-lg d-flex align-items-center cq-option-btn';\n        }\n      });\n      \n      \/\/ \u66f4\u65b0\u9032\u5ea6\n      pageManager.updateProgress();\n      \n      \/\/ \u986f\u793a\/\u96b1\u85cf\u4e0a\u4e00\u984c\u6309\u9215\n      if (state.currentQuestion > 0) {\n        elements.prevBtn.classList.remove('d-none');\n      } else {\n        elements.prevBtn.classList.add('d-none');\n      }\n      \n      \/\/ \u6efe\u52d5\u5230\u554f\u984c\u6a19\u984c\n      setTimeout(() => {\n        const quizTitle = elements.quizPage.querySelector('h2');\n        utils.scrollToElement(quizTitle, -20);\n      }, 100);\n    },\n\n    selectOption: (value) => {\n      \/\/ \u8a18\u9304\u7b54\u6848\n      state.answers[state.currentQuestion] = parseInt(value);\n      \n      \/\/ \u8996\u89ba\u53cd\u994b\n      elements.optionButtons.forEach(btn => {\n        btn.classList.remove('cq-selected');\n        if (btn.dataset.value === value) {\n          btn.classList.add('cq-selected');\n        }\n      });\n      \n      \/\/ \u5ef6\u9072\u9032\u5165\u4e0b\u4e00\u984c\n      setTimeout(() => {\n        quizManager.nextQuestion();\n      }, 500);\n    },\n\n    nextQuestion: () => {\n      state.currentQuestion++;\n      \n      if (state.currentQuestion >= QUIZ_DATA.questions.length) {\n        quizManager.finishQuiz();\n      } else {\n        quizManager.displayQuestion();\n      }\n    },\n\n    prevQuestion: () => {\n      if (state.currentQuestion > 0) {\n        state.currentQuestion--;\n        quizManager.displayQuestion();\n      }\n    },\n\n    finishQuiz: () => {\n      \/\/ \u8a08\u7b97\u7e3d\u5206\n      state.totalScore = state.answers.reduce((sum, answer) => sum + answer, 0);\n      \n      \/\/ \u986f\u793a\u7d50\u679c\u9801\n      pageManager.showPage('result');\n      resultManager.displayResults();\n    }\n  };\n\n  \/\/ \u7d50\u679c\u7ba1\u7406\n  const resultManager = {\n    displayResults: () => {\n      const interpretation = utils.getScoreInterpretation(state.totalScore);\n      const dimensions = utils.calculateDimensions(state.answers);\n      \n      \/\/ \u986f\u793a\u7e3d\u5206\n      elements.scoreDisplay.textContent = state.totalScore;\n      \n      \/\/ \u986f\u793a\u5206\u6790\u5167\u5bb9\n      elements.analysisContent.innerHTML = `\n        <div class=\"text-center mb-4\">\n          <span class=\"badge ${interpretation.badgeClass} fs-6 px-3 py-2\">${interpretation.title}<\/span>\n        <\/div>\n        <p class=\"mb-0 lead text-center\">${interpretation.description}<\/p>\n      `;\n      \n      \/\/ \u986f\u793a\u7dad\u5ea6\u5206\u6790\n      resultManager.displayDimensions(dimensions);\n      \n      \/\/ \u5275\u5efa\u5716\u8868\n      setTimeout(() => {\n        resultManager.createChart(dimensions, interpretation);\n      }, 300);\n    },\n\n    displayDimensions: (dimensions) => {\n      elements.dimensionsGrid.innerHTML = Object.values(dimensions)\n        .map(dimension => `\n          <div class=\"col-md-6 col-lg-4\">\n            <div class=\"cq-dimension-item\">\n              <div class=\"cq-dimension-name\">${dimension.name}<\/div>\n              <div class=\"cq-dimension-score\">${dimension.score}%<\/div>\n            <\/div>\n          <\/div>\n        `).join('');\n    },\n\n    createChart: (dimensions, interpretation) => {\n      const canvas = document.getElementById('cq-confidence-chart');\n      if (!canvas) return;\n\n      const ctx = canvas.getContext('2d');\n      \n      \/\/ \u5982\u679c\u5df2\u5b58\u5728\u56fe\u8868\uff0c\u5148\u9500\u6bc1\n      if (window.confidenceChart) {\n        window.confidenceChart.destroy();\n      }\n      \n      \/\/ \u6e96\u5099\u6578\u64da\n      const labels = Object.values(dimensions).map(d => d.name);\n      const data = Object.values(dimensions).map(d => d.score);\n      \n      \/\/ \u521b\u5efa\u56fe\u8868\u5e76\u4fdd\u5b58\u5f15\u7528\n      window.confidenceChart = new Chart(ctx, {\n        type: 'radar',\n        data: {\n          labels: labels,\n          datasets: [{\n            label: '\u81ea\u4fe1\u5fc3\u5404\u7dad\u5ea6\u8868\u73fe',\n            data: data,\n            backgroundColor: `${interpretation.color}20`,\n            borderColor: interpretation.color,\n            borderWidth: 3,\n            pointBackgroundColor: interpretation.color,\n            pointBorderColor: '#ffffff',\n            pointBorderWidth: 2,\n            pointRadius: 6,\n            pointHoverRadius: 8\n          }]\n        },\n        options: {\n          responsive: true,\n          maintainAspectRatio: false,\n          layout: {\n            padding: {\n              top: 20,\n              bottom: 20,\n              left: 20,\n              right: 20\n            }\n          },\n          plugins: {\n            legend: {\n              display: false\n            }\n          },\n          scales: {\n            r: {\n              beginAtZero: true,\n              min: 0,\n              max: 100,\n              angleLines: {\n                color: 'rgba(0, 0, 0, 0.1)',\n                lineWidth: 1\n              },\n              grid: {\n                color: 'rgba(0, 0, 0, 0.1)',\n                lineWidth: 1\n              },\n              pointLabels: {\n                color: '#374151',\n                font: {\n                  size: function(context) {\n                    \/\/ \u6839\u636e\u753b\u5e03\u5927\u5c0f\u52a8\u6001\u8c03\u6574\u5b57\u4f53\n                    const width = context.chart.width;\n                    if (width < 400) return 14;\n                    if (width < 600) return 16;\n                    return 18;\n                  },\n                  weight: '500'\n                },\n                padding: 10\n              },\n              ticks: {\n                color: '#6b7280',\n                font: {\n                  size: function(context) {\n                    const width = context.chart.width;\n                    return width < 400 ? 10 : 12;\n                  }\n                },\n                stepSize: 20,\n                showLabelBackdrop: false,\n                z: 1\n              }\n            }\n          },\n          elements: {\n            point: {\n              radius: function(context) {\n                const width = context.chart.width;\n                return width < 400 ? 4 : 6;\n              },\n              hoverRadius: function(context) {\n                const width = context.chart.width;\n                return width < 400 ? 6 : 8;\n              }\n            },\n            line: {\n              borderWidth: function(context) {\n                const width = context.chart.width;\n                return width < 400 ? 2 : 3;\n              }\n            }\n          }\n        }\n      });\n      \n      \/\/ \u76d1\u542c\u7a97\u53e3\u5927\u5c0f\u53d8\u5316\uff0c\u91cd\u65b0\u8c03\u6574\u56fe\u8868\n      const resizeObserver = new ResizeObserver(entries => {\n        if (window.confidenceChart) {\n          window.confidenceChart.resize();\n        }\n      });\n      \n      const chartContainer = canvas.closest('.cq-chart-container');\n      if (chartContainer) {\n        resizeObserver.observe(chartContainer);\n      }\n    }\n  };\n\n  \/\/ \u4e8b\u4ef6\u7ba1\u7406\n  const eventManager = {\n    init: () => {\n      \/\/ \u4f7f\u7528\u4e8b\u4ef6\u59d4\u6258\u8655\u7406\u6240\u6709\u9ede\u64ca\u4e8b\u4ef6\n      elements.container.addEventListener('click', eventManager.handleClick);\n      \n      \/\/ \u9375\u76e4\u4e8b\u4ef6\u652f\u63f4\n      document.addEventListener('keydown', eventManager.handleKeydown);\n    },\n\n    handleClick: (event) => {\n      const target = event.target;\n      const action = target.dataset.action || target.closest('[data-action]')?.dataset.action;\n      \n      switch (action) {\n        case 'start-quiz':\n          event.preventDefault();\n          quizManager.startQuiz();\n          break;\n          \n        case 'prev-question':\n          event.preventDefault();\n          quizManager.prevQuestion();\n          break;\n          \n        case 'restart-quiz':\n          event.preventDefault();\n          pageManager.showPage('welcome');\n          break;\n      }\n      \n      \/\/ \u8655\u7406\u9078\u9805\u9ede\u64ca\n      const optionBtn = target.closest('.cq-option-btn');\n      if (optionBtn) {\n        event.preventDefault();\n        const value = optionBtn.dataset.value;\n        quizManager.selectOption(value);\n      }\n    },\n\n    handleKeydown: (event) => {\n      if (state.currentPage === 'quiz') {\n        switch (event.key) {\n          case '1':\n            quizManager.selectOption('1');\n            break;\n          case '0':\n            quizManager.selectOption('0');\n            break;\n          case 'ArrowLeft':\n            if (state.currentQuestion > 0) {\n              event.preventDefault();\n              quizManager.prevQuestion();\n            }\n            break;\n        }\n      }\n    }\n  };\n\n  \/\/ \u521d\u59cb\u5316\u51fd\u6578\n  const init = () => {\n    \/\/ \u5feb\u53d6 DOM \u5143\u7d20\n    elements.container = document.querySelector('[data-quiz=\"confidence-assessment\"]');\n    if (!elements.container) {\n      console.error('Quiz container not found');\n      return;\n    }\n\n    elements.welcomePage = elements.container.querySelector('[data-page=\"welcome\"]');\n    elements.quizPage = elements.container.querySelector('[data-page=\"quiz\"]');\n    elements.resultPage = elements.container.querySelector('[data-page=\"result\"]');\n    elements.questionText = elements.container.querySelector('[data-question-text]');\n    elements.optionButtons = elements.container.querySelectorAll('.cq-option-btn');\n    elements.progressInfo = elements.container.querySelector('.cq-progress-container');\n    elements.progressFill = elements.container.querySelector('.cq-progress-fill');\n    elements.prevBtn = elements.container.querySelector('.cq-prev-btn');\n    elements.scoreDisplay = elements.container.querySelector('[data-score-display]');\n    elements.analysisContent = elements.container.querySelector('[data-analysis-content]');\n    elements.dimensionsGrid = elements.container.querySelector('[data-dimensions-grid]');\n\n    \/\/ \u521d\u59cb\u5316\u4e8b\u4ef6\u76e3\u807d\u5668\n    eventManager.init();\n    \n    \/\/ \u6dfb\u52a0\u7a97\u53e3\u5927\u5c0f\u53d8\u5316\u76d1\u542c\u5668\n    let resizeTimeout;\n    window.addEventListener('resize', () => {\n      clearTimeout(resizeTimeout);\n      resizeTimeout = setTimeout(() => {\n        if (window.confidenceChart && state.currentPage === 'result') {\n          window.confidenceChart.resize();\n        }\n      }, 250);\n    });\n    \n    \/\/ \u986f\u793a\u6b61\u8fce\u9801\n    pageManager.showPage('welcome');\n    \n    console.log('\u7d14Bootstrap\u7248\u81ea\u4fe1\u5fc3\u8a55\u4f30\u6e2c\u9a57\u7cfb\u7d71\u5df2\u521d\u59cb\u5316');\n  };\n\n  \/\/ \u7576 DOM \u52a0\u8f09\u5b8c\u6210\u6642\u521d\u59cb\u5316\n  if (document.readyState === 'loading') {\n    document.addEventListener('DOMContentLoaded', init);\n  } else {\n    init();\n  }\n\n})();\n<\/script>","protected":false},"excerpt":{"rendered":"<p>\u6b22\u8fce\u53c2\u52a0\u81ea\u4fe1\u5fc3\u8bc4\u4f30\uff01\u672c\u6d4b\u8bd5\u517140\u9898\uff0c\u900f\u8fc7\u65e5\u5e38\u884c\u4e3a\u4e0e\u5fc3\u7406\u72b6\u6001\u8bc4\u4f30\u60a8\u7684\u81ea\u4fe1\u6c34\u5e73\u3002\u8bf7\u6839\u636e\u7b2c\u4e00\u53cd\u5e94\u5982\u5b9e\u4f5c\u7b54\uff0c\u9009\u62e9\u201d\u662f\u201d\u6216\u201d\u5426\u201d\uff0c\u65e0\u9700\u8fc7\u591a\u601d\u8003\u3002<\/p>","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"site-sidebar-layout":"default","site-content-layout":"","ast-site-content-layout":"narrow-width-container","site-content-style":"default","site-sidebar-style":"default","ast-global-header-display":"disabled","ast-banner-title-visibility":"","ast-main-header-display":"","ast-hfb-above-header-display":"","ast-hfb-below-header-display":"","ast-hfb-mobile-header-display":"","site-post-title":"","ast-breadcrumbs-content":"","ast-featured-img":"","footer-sml-layout":"","ast-disable-related-posts":"","theme-transparent-header-meta":"","adv-header-id-meta":"","stick-header-meta":"","header-above-stick-meta":"","header-main-stick-meta":"","header-below-stick-meta":"","astra-migrate-meta-layouts":"default","ast-page-background-enabled":"default","ast-page-background-meta":{"desktop":{"background-color":"var(--ast-global-color-4)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""},"tablet":{"background-color":"","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""},"mobile":{"background-color":"","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""}},"ast-content-background-meta":{"desktop":{"background-color":"var(--ast-global-color-5)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""},"tablet":{"background-color":"var(--ast-global-color-5)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""},"mobile":{"background-color":"var(--ast-global-color-5)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""}},"footnotes":""},"categories":[167,160],"tags":[],"class_list":["post-9047","post","type-post","status-publish","format-standard","hentry","category-personality","category-attitude-scales"],"_links":{"self":[{"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/posts\/9047","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/comments?post=9047"}],"version-history":[{"count":5,"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/posts\/9047\/revisions"}],"predecessor-version":[{"id":10030,"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/posts\/9047\/revisions\/10030"}],"wp:attachment":[{"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/media?parent=9047"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/categories?post=9047"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/tags?post=9047"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}