{"id":2717,"date":"2023-10-20T08:33:15","date_gmt":"2023-10-20T00:33:15","guid":{"rendered":"https:\/\/bookmark.tw\/?p=2717"},"modified":"2025-05-10T21:49:29","modified_gmt":"2025-05-10T13:49:29","slug":"desired-relationships","status":"publish","type":"post","link":"https:\/\/xinliceyan.org\/zh\/desired-relationships","title":{"rendered":"\u7ebf\u4e0a\u514d\u8d39\u5c0f\u6d4b\u9a8c\uff1a\u4f60\u60f3\u62e5\u6709\u7684\u4eba\u9645\u5173\u7cfb"},"content":{"rendered":"<!-- \u4eba\u969b\u95dc\u4fc2\u5fc3\u7406\u6e2c\u9a57 - WordPress\u5d4c\u5165\u4ee3\u78bc -->\n<div id=\"personality-quiz-container\">\n  <!-- HTML \u7d50\u69cb -->\n  <main class=\"quiz-wrapper\" data-quiz=\"relationship-personality\">\n    <!-- \u5f15\u5c0e\u9801 -->\n    <section class=\"quiz-page\" data-page=\"intro\" aria-label=\"\u6d4b\u9a8c\u4ecb\u7ecd\">\n      <header class=\"quiz-header\">\n        <h2 class=\"quiz-title\">\u4f60\u60f3\u62e5\u6709\u7684\u4eba\u9645\u5173\u7cfb<\/h2>\n        <p class=\"quiz-subtitle\">\u63a2\u7d22\u4f60\u7684\u5fc3\u7406\u72b6\u6001\u4e0e\u4eba\u9645\u5173\u7cfb\u503e\u5411<\/p>\n      <\/header>\n      \n      <article class=\"intro-content\">\n        <div class=\"intro-features\">\n          <div class=\"feature-item\">\n            <div class=\"feature-icon\">\n              <svg viewbox=\"0 0 24 24\" fill=\"currentColor\">\n                <path d=\"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 15l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z\"\/>\n              <\/svg>\n            <\/div>\n            <h3>\u51c6\u786e\u5206\u6790<\/h3>\n            <p>\u900f\u8fc7\u7b80\u5355\u7684\u56fe\u5f62\u9009\u62e9,\u6df1\u5165\u4e86\u89e3\u4f60\u7684\u5185\u5fc3\u9700\u6c42<\/p>\n          <\/div>\n          \n          <div class=\"feature-item\">\n            <div class=\"feature-icon\">\n              <svg viewbox=\"0 0 24 24\" fill=\"currentColor\">\n                <path d=\"M16 11c1.66 0 2.99-1.34 2.99-3S17.66 5 16 5c-1.66 0-3 1.34-3 3s1.34 3 3 3zm-8 0c1.66 0 2.99-1.34 2.99-3S9.66 5 8 5C6.34 5 5 6.34 5 8s1.34 3 3 3zm0 2c-2.33 0-7 1.17-7 3.5V19h14v-2.5c0-2.33-4.67-3.5-7-3.5zm8 0c-.29 0-.62.02-.97.05 1.16.84 1.97 1.97 1.97 3.45V19h6v-2.5c0-2.33-4.67-3.5-7-3.5z\"\/>\n              <\/svg>\n            <\/div>\n            <h3>\u4eba\u9645\u6d1e\u5bdf<\/h3>\n            <p>\u63ed\u793a\u4f60\u5728\u4eba\u9645\u5173\u7cfb\u4e2d\u7684\u771f\u5b9e\u9700\u6c42\u4e0e\u671f\u5f85<\/p>\n          <\/div>\n          \n          <div class=\"feature-item\">\n            <div class=\"feature-icon\">\n              <svg viewbox=\"0 0 24 24\" fill=\"currentColor\">\n                <path d=\"M9 11H7v2h2v-2zm4 0h-2v2h2v-2zm4 0h-2v2h2v-2zm2-7h-1V2h-2v2H8V2H6v2H5c-1.11 0-1.99.9-1.99 2L3 20c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 16H5V9h14v11z\"\/>\n              <\/svg>\n            <\/div>\n            <h3>\u5373\u65f6\u7ed3\u679c<\/h3>\n            <p>\u5feb\u901f\u83b7\u5f97\u4e13\u4e1a\u7684\u5fc3\u7406\u5206\u6790\u7ed3\u679c<\/p>\n          <\/div>\n        <\/div>\n        \n        <div class=\"intro-description\">\n          <p>\u6bcf\u5929\u65e9\u4e0a\u8d77\u5e8a\uff0c\u6211\u4eec\u7684\u5fc3\u60c5\u90fd\u4e0d\u540c\u3002\u6709\u65f6\u89c9\u5f97\u300c\u4eca\u5929\u7684\u5fc3\u60c5\u4e0d\u9519\u300d\uff0c\u6709\u65f6\u5219\u611f\u5230\u300c\u4eca\u5929\u6709\u70b9\u4e0d\u5bf9\u52b2\u300d\u3002<\/p>\n          <p>\u8fd9\u4e2a\u6d4b\u9a8c\u900f\u8fc7\u4e00\u4e2a\u7b80\u5355\u7684\u5706\u5f62\u7ed8\u56fe\u9009\u62e9\uff0c\u6765\u5224\u65ad\u4f60\u5185\u5fc3\u6df1\u5904\u5bf9\u4eba\u9645\u5173\u7cfb\u7684\u771f\u5b9e\u60f3\u6cd5\u3002<\/p>\n        <\/div>\n        \n        <button class=\"btn-start\" data-action=\"start-quiz\" aria-label=\"\u5f00\u59cb\u6d4b\u9a8c\">\n          \u5f00\u59cb\u6d4b\u9a8c\n          <span class=\"btn-arrow\">\u2192<\/span>\n        <\/button>\n      <\/article>\n    <\/section>\n    \n    <!-- \u6e2c\u9a57\u9801 -->\n    <section class=\"quiz-page\" data-page=\"questions\" aria-label=\"\u6d4b\u9a8c\u95ee\u9898\" style=\"display: none;\">\n      <header class=\"quiz-header\">\n        <h2 class=\"quiz-title\">\u5fc3\u7406\u6d4b\u9a8c<\/h2>\n      <\/header>\n      \n      <div class=\"question-container\" data-question=\"0\">\n        <h3 class=\"question-text\">\u5706\u662f\u81ea\u5df1\u6216\u4ed6\u4eba\u4eba\u683c\u7684\u8c61\u5f81\u3002\u8bf7\u60f3\u50cf\u5728\u539f\u6765\u7684\u4e00\u4e2a\u5706\u5982\u4f55\u52a0\u4e0a\u4e00\u4e2a\u65b0\u7684\u5706\uff0c\u4ece\u4f60\u7684\u9009\u62e9\u53ef\u4ee5\u77e5\u9053\u4f60\u60f3\u5982\u4f55\u4e0e\u670b\u53cb\u4ea4\u5f80\u3002<\/h3>\n        \n        <div class=\"options-container\" role=\"radiogroup\" aria-label=\"\u9009\u62e9\u5982\u4f55\u753b\u5706\">\n          <label class=\"option-item\" data-value=\"A\">\n            <input type=\"radio\" name=\"question-0\" value=\"A\" aria-label=\"\u9009\u9879A\">\n            <span class=\"option-content\">\n              <span class=\"option-letter\">A<\/span>\n              <span class=\"option-text\">\u753b\u4e00\u4e2a\u5927\u5706\u56f4\u4f4f\u539f\u6765\u7684\u5706<\/span>\n            <\/span>\n          <\/label>\n          \n          <label class=\"option-item\" data-value=\"B\">\n            <input type=\"radio\" name=\"question-0\" value=\"B\" aria-label=\"\u9009\u9879B\">\n            <span class=\"option-content\">\n              <span class=\"option-letter\">B<\/span>\n              <span class=\"option-text\">\u753b\u4e00\u4e2a\u5c0f\u5706\u5728\u539f\u6765\u7684\u5706\u5185\u90e8<\/span>\n            <\/span>\n          <\/label>\n          \n          <label class=\"option-item\" data-value=\"C\">\n            <input type=\"radio\" name=\"question-0\" value=\"C\" aria-label=\"\u9009\u9879C\">\n            <span class=\"option-content\">\n              <span class=\"option-letter\">C<\/span>\n              <span class=\"option-text\">\u753b\u4e00\u4e2a\u5706\u548c\u539f\u6765\u7684\u5706\u76f8\u4ea4<\/span>\n            <\/span>\n          <\/label>\n          \n          <label class=\"option-item\" data-value=\"D\">\n            <input type=\"radio\" name=\"question-0\" value=\"D\" aria-label=\"\u9009\u9879D\">\n            <span class=\"option-content\">\n              <span class=\"option-letter\">D<\/span>\n              <span class=\"option-text\">\u5728\u539f\u6765\u7684\u5706\u7684\u65c1\u8fb9\u753b\u53e6\u4e00\u4e2a\u5706<\/span>\n            <\/span>\n          <\/label>\n        <\/div>\n      <\/div>\n    <\/section>\n    \n    <!-- \u7d50\u679c\u9801 -->\n    <section class=\"quiz-page\" data-page=\"results\" aria-label=\"\u6d4b\u9a8c\u7ed3\u679c\" style=\"display: none;\">\n      <header class=\"quiz-header\">\n        <h2 class=\"quiz-title\">\u4f60\u7684\u6d4b\u9a8c\u7ed3\u679c<\/h2>\n      <\/header>\n      \n      <article class=\"results-content\">\n        <div class=\"result-chart-container\">\n          <canvas id=\"personality-chart\"><\/canvas>\n        <\/div>\n        \n        <div class=\"result-analysis\">\n          <h3 class=\"analysis-title\">\u5fc3\u7075\u89e3\u6790<\/h3>\n          <div class=\"analysis-text\" data-result-text><\/div>\n        <\/div>\n        \n        <button class=\"btn-restart\" data-action=\"restart-quiz\" aria-label=\"\u91cd\u65b0\u6d4b\u8bd5\">\n          \u91cd\u65b0\u6d4b\u8bd5\n        <\/button>\n      <\/article>\n    <\/section>\n  <\/main>\n  \n  <!-- CSS \u6a23\u5f0f -->\n  <style>\n    \/* CSS \u8b8a\u6578 - \u914d\u8272\u65b9\u6848 *\/\n    #personality-quiz-container {\n      --primary-color: #4F46E5;\n      --primary-hover: #4338CA;\n      --secondary-color: #7C3AED;\n      --accent-color: #EC4899;\n      --text-primary: #1F2937;\n      --text-secondary: #6B7280;\n      --bg-primary: #FFFFFF;\n      --bg-secondary: #F9FAFB;\n      --bg-tertiary: #F3F4F6;\n      --border-color: #E5E7EB;\n      --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);\n      --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);\n      --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);\n      --transition: all 0.3s ease;\n      --border-radius: 12px;\n    }\n    \n    \/* \u57fa\u790e\u6a23\u5f0f\u91cd\u7f6e - \u78ba\u4fdd\u53ea\u5f71\u97ff\u5bb9\u5668\u5167\u5143\u7d20 *\/\n    #personality-quiz-container * {\n      margin: 0;\n      padding: 0;\n      box-sizing: border-box;\n    }\n    \n    #personality-quiz-container {\n      font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif;\n      line-height: 1.6;\n      color: var(--text-primary);\n    }\n    \n    \/* \u5bb9\u5668\u6a23\u5f0f *\/\n    #personality-quiz-container .quiz-wrapper {\n      max-width: 800px;\n      margin: 0 auto;\n      padding: 24px;\n      min-height: 600px;\n    }\n    \n    \/* \u9801\u9762\u57fa\u790e\u6a23\u5f0f *\/\n    #personality-quiz-container .quiz-page {\n      opacity: 0;\n      transition: opacity 0.3s ease;\n    }\n    \n    #personality-quiz-container .quiz-page[data-page=\"intro\"] {\n      opacity: 1;\n    }\n    \n    \/* \u6a19\u984c\u6a23\u5f0f *\/\n    #personality-quiz-container .quiz-header {\n      text-align: center;\n      margin-bottom: 40px;\n    }\n    \n    #personality-quiz-container .quiz-title {\n      font-size: 36px;\n      font-weight: 700;\n      color: var(--primary-color);\n      margin-bottom: 12px;\n      line-height: 1.2;\n    }\n    \n    #personality-quiz-container .quiz-subtitle {\n      font-size: 20px;\n      color: var(--text-secondary);\n      font-weight: 400;\n    }\n    \n    \/* \u5f15\u5c0e\u9801\u6a23\u5f0f *\/\n    #personality-quiz-container .intro-content {\n      display: flex;\n      flex-direction: column;\n      align-items: center;\n    }\n    \n    #personality-quiz-container .intro-features {\n      display: grid;\n      grid-template-columns: repeat(3, 1fr);\n      gap: 16px;\n      margin-bottom: 48px;\n      width: 100%;\n    }\n    \n    #personality-quiz-container .feature-item {\n      text-align: center;\n      padding: 16px 8px;\n      background: var(--bg-secondary);\n      border-radius: var(--border-radius);\n      transition: var(--transition);\n    }\n    \n    #personality-quiz-container .feature-item:hover {\n      transform: translateY(-4px);\n      box-shadow: var(--shadow-lg);\n    }\n    \n    #personality-quiz-container .feature-icon {\n      width: 56px;\n      height: 56px;\n      margin: 0 auto 12px;\n      background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));\n      border-radius: 50%;\n      display: flex;\n      align-items: center;\n      justify-content: center;\n      color: white;\n      box-shadow: var(--shadow-md);\n    }\n    \n    #personality-quiz-container .feature-icon svg {\n      width: 32px;\n      height: 32px;\n    }\n    \n    #personality-quiz-container .feature-item h3 {\n      font-size: 16px;\n      font-weight: 600;\n      margin-bottom: 8px;\n      color: var(--text-primary);\n    }\n    \n    #personality-quiz-container .feature-item p {\n      font-size: 14px;\n      color: var(--text-secondary);\n      line-height: 1.4;\n    }\n    \n    #personality-quiz-container .intro-description {\n      text-align: left;\n      margin-bottom: 40px;\n      background: var(--bg-tertiary);\n      padding: 32px;\n      border-radius: var(--border-radius);\n      border-left: 4px solid var(--primary-color);\n      width: 100%;\n    }\n    \n    #personality-quiz-container .intro-description p {\n      font-size: 18px;\n      color: var(--text-primary);\n      margin-bottom: 16px;\n      line-height: 1.6;\n    }\n    \n    #personality-quiz-container .intro-description p:last-child {\n      margin-bottom: 0;\n    }\n    \n    \/* \u6309\u9215\u6a23\u5f0f *\/\n    #personality-quiz-container .btn-start,\n    #personality-quiz-container .btn-restart {\n      display: flex;\n      align-items: center;\n      justify-content: center;\n      gap: 12px;\n      min-width: 200px;\n      height: 56px;\n      padding: 0 32px;\n      font-size: 18px;\n      font-weight: 600;\n      color: white;\n      background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));\n      border: none;\n      border-radius: var(--border-radius);\n      cursor: pointer;\n      transition: var(--transition);\n      box-shadow: var(--shadow-md);\n      margin: 0 auto;\n    }\n    \n    #personality-quiz-container .btn-start:hover,\n    #personality-quiz-container .btn-restart:hover {\n      transform: translateY(-2px);\n      box-shadow: var(--shadow-lg);\n      filter: brightness(1.1);\n    }\n    \n    #personality-quiz-container .btn-arrow {\n      font-size: 20px;\n      transition: transform 0.3s ease;\n    }\n    \n    #personality-quiz-container .btn-start:hover .btn-arrow {\n      transform: translateX(4px);\n    }\n    \n    \/* \u554f\u984c\u9801\u6a23\u5f0f *\/\n    #personality-quiz-container .question-container {\n      max-width: 680px;\n      margin: 0 auto;\n    }\n    \n    #personality-quiz-container .question-text {\n      font-size: 22px;\n      font-weight: 700;\n      color: var(--text-primary);\n      margin-bottom: 32px;\n      line-height: 1.5;\n      text-align: left;\n    }\n    \n    #personality-quiz-container .options-container {\n      display: flex;\n      flex-direction: column;\n      gap: 16px;\n    }\n    \n    #personality-quiz-container .option-item {\n      position: relative;\n      cursor: pointer;\n      transition: var(--transition);\n      display: block;\n    }\n    \n    #personality-quiz-container .option-item input[type=\"radio\"] {\n      position: absolute;\n      opacity: 0;\n      width: 0;\n      height: 0;\n    }\n    \n    #personality-quiz-container .option-content {\n      display: flex;\n      align-items: center;\n      gap: 16px;\n      padding: 20px 24px;\n      min-height: 60px;\n      background: var(--bg-secondary);\n      border: 2px solid var(--border-color);\n      border-radius: var(--border-radius);\n      transition: var(--transition);\n      color: var(--text-primary);\n    }\n    \n    #personality-quiz-container .option-letter {\n      width: 36px;\n      height: 36px;\n      background: var(--primary-color);\n      color: white;\n      border-radius: 50%;\n      display: flex;\n      align-items: center;\n      justify-content: center;\n      font-weight: 600;\n      font-size: 18px;\n      flex-shrink: 0;\n    }\n    \n    #personality-quiz-container .option-text {\n      font-size: 18px;\n      color: var(--text-primary);\n      flex: 1;\n    }\n    \n    #personality-quiz-container .option-item:hover .option-content {\n      border-color: var(--primary-color);\n      background: var(--bg-tertiary);\n      transform: translateX(8px);\n    }\n    \n    #personality-quiz-container .option-item input[type=\"radio\"]:checked + .option-content {\n      border-color: var(--primary-color);\n      background: var(--bg-primary);\n      box-shadow: var(--shadow-md);\n    }\n    \n    #personality-quiz-container .option-item input[type=\"radio\"]:checked + .option-content .option-letter {\n      background: var(--secondary-color);\n    }\n    \n    \/* \u7d50\u679c\u9801\u6a23\u5f0f *\/\n    #personality-quiz-container .results-content {\n      display: flex;\n      flex-direction: column;\n      align-items: center;\n      max-width: 680px;\n      margin: 0 auto;\n    }\n    \n    #personality-quiz-container .result-chart-container {\n      width: 100%;\n      max-width: 500px;\n      margin: 0 auto 48px;\n      padding: 24px;\n      background: var(--bg-secondary);\n      border-radius: var(--border-radius);\n      box-shadow: var(--shadow-md);\n    }\n    \n    #personality-quiz-container #personality-chart {\n      max-width: 100%;\n      height: 400px !important;\n    }\n    \n    #personality-quiz-container .result-analysis {\n      background: var(--bg-tertiary);\n      padding: 32px;\n      border-radius: var(--border-radius);\n      margin-bottom: 40px;\n      border-left: 4px solid var(--primary-color);\n      width: 100%;\n    }\n    \n    #personality-quiz-container .analysis-title {\n      font-size: 24px;\n      font-weight: 700;\n      color: var(--primary-color);\n      margin-bottom: 20px;\n      text-align: center;\n    }\n    \n    #personality-quiz-container .analysis-text {\n      font-size: 18px;\n      color: var(--text-primary);\n      line-height: 1.7;\n      text-align: left;\n    }\n    \n    \/* 600px\u5bec\u5ea6\u7684\u7279\u6b8a\u8655\u7406 *\/\n    @media (max-width: 600px) {\n      #personality-quiz-container .intro-features {\n        grid-template-columns: repeat(3, 1fr);\n        gap: 12px;\n      }\n      \n      #personality-quiz-container .feature-item {\n        padding: 12px 6px;\n      }\n      \n      #personality-quiz-container .feature-icon {\n        width: 48px;\n        height: 48px;\n      }\n      \n      #personality-quiz-container .feature-icon svg {\n        width: 28px;\n        height: 28px;\n      }\n      \n      #personality-quiz-container .feature-item h3 {\n        font-size: 14px;\n      }\n      \n      #personality-quiz-container .feature-item p {\n        font-size: 12px;\n      }\n    }\n    \n    \/* \u5c0f\u65bc480px\u6642\u6539\u70ba\u5782\u76f4\u6392\u5217 *\/\n    @media (max-width: 480px) {\n      #personality-quiz-container .intro-features {\n        grid-template-columns: 1fr;\n        gap: 16px;\n      }\n      \n      #personality-quiz-container .feature-item {\n        padding: 16px;\n      }\n      \n      #personality-quiz-container .feature-icon {\n        width: 56px;\n        height: 56px;\n      }\n      \n      #personality-quiz-container .feature-item h3 {\n        font-size: 16px;\n      }\n      \n      #personality-quiz-container .feature-item p {\n        font-size: 14px;\n      }\n    }\n    \n    \/* \u97ff\u61c9\u5f0f\u8a2d\u8a08 *\/\n    @media (max-width: 768px) {\n      #personality-quiz-container .quiz-wrapper {\n        padding: 16px;\n      }\n      \n      #personality-quiz-container .quiz-title {\n        font-size: 28px;\n      }\n      \n      #personality-quiz-container .quiz-subtitle {\n        font-size: 18px;\n      }\n      \n      #personality-quiz-container .intro-features {\n        grid-template-columns: 1fr;\n        gap: 24px;\n      }\n      \n      #personality-quiz-container .feature-item {\n        padding: 20px;\n      }\n      \n      #personality-quiz-container .feature-icon {\n        width: 60px;\n        height: 60px;\n      }\n      \n      #personality-quiz-container .intro-description {\n        padding: 24px;\n      }\n      \n      #personality-quiz-container .intro-description p {\n        font-size: 16px;\n      }\n      \n      #personality-quiz-container .question-text {\n        font-size: 20px;\n      }\n      \n      #personality-quiz-container .option-text {\n        font-size: 16px;\n      }\n      \n      #personality-quiz-container .btn-start,\n      #personality-quiz-container .btn-restart {\n        width: 100%;\n      }\n      \n      #personality-quiz-container #personality-chart {\n        height: 300px !important;\n      }\n    }\n    \n    @media (max-width: 480px) {\n      #personality-quiz-container .quiz-title {\n        font-size: 24px;\n      }\n      \n      #personality-quiz-container .quiz-subtitle {\n        font-size: 16px;\n      }\n      \n      #personality-quiz-container .feature-item h3 {\n        font-size: 18px;\n      }\n      \n      #personality-quiz-container .feature-item p {\n        font-size: 14px;\n      }\n      \n      #personality-quiz-container .question-text {\n        font-size: 18px;\n      }\n      \n      #personality-quiz-container .option-content {\n        padding: 16px;\n      }\n      \n      #personality-quiz-container .option-letter {\n        width: 32px;\n        height: 32px;\n        font-size: 16px;\n      }\n      \n      #personality-quiz-container .analysis-title {\n        font-size: 20px;\n      }\n      \n      #personality-quiz-container .analysis-text {\n        font-size: 16px;\n      }\n    }\n  <\/style>\n  \n  <!-- JavaScript -->\n  <script>\n    (function() {\n      'use strict';\n      \n      \/\/ \u6e2c\u9a57\u7d50\u679c\u6578\u64da\n      const results = {\n        A: {\n          title: '\u64f4\u5c55\u578b\u4eba\u683c',\n          description: '\u5fc3\u4e2d\u5145\u6eff\u81ea\u6211\u64f4\u5f35\u7684\u9700\u6c42\uff0c\u65e2\u60f3\u7dad\u6301\u76ee\u524d\u7684\u4eba\u969b\u95dc\u4fc2\uff0c\u4e5f\u60f3\u7a4d\u6975\u5730\u64f4\u5c55\u65b0\u7684\u4eba\u969b\u95dc\u4fc2\uff0c\u5145\u6eff\u5411\u65b0\u7684\u53ef\u80fd\u6027\u548c\u6311\u6230\u7684\u5fc3\u60c5\u3002',\n          scores: {\n            '\u793e\u4ea4\u958b\u653e\u5ea6': 90,\n            '\u4eba\u969b\u7a4d\u6975\u6027': 85,\n            '\u95dc\u4fc2\u7dad\u8b77\u529b': 80,\n            '\u5192\u96aa\u7cbe\u795e': 88\n          }\n        },\n        B: {\n          title: '\u5167\u7701\u578b\u4eba\u683c',\n          description: '\u62b1\u8457\u60f3\u5c01\u9589\u81ea\u5df1\u7684\u5167\u7701\u5fc3\u7406\uff0c\u5e0c\u671b\u7a69\u5b9a\u5728\u76ee\u524d\u81ea\u5df1\u6240\u719f\u6089\u7684\u3001\u5b89\u5168\u7684\u4eba\u969b\u95dc\u4fc2\u4e2d\uff0c\u6c89\u6d78\u5728\u81ea\u5df1\u7684\u5c0f\u4e16\u754c\u88cf\u3002',\n          scores: {\n            '\u5167\u5411\u601d\u8003': 90,\n            '\u5b89\u5168\u9700\u6c42': 85,\n            '\u7a69\u5b9a\u6027': 92,\n            '\u81ea\u6211\u4fdd\u8b77': 88\n          }\n        },\n        C: {\n          title: '\u8b8a\u9769\u578b\u4eba\u683c',\n          description: '\u662f\u5426\u5c0d\u76ee\u524d\u7684\u72c0\u6cc1\u611f\u5230\u4e0d\u6eff\uff1f\u5713\u548c\u5713\u4ea4\u758a\u5728\u4e00\u8d77\uff0c\u8868\u793a\u81ea\u5df1\u60f3\u8207\u67d0\u500b\u4eba\u5728\u4e00\u8d77\uff0c\u5982\u679c\u662f\u7570\u6027\u5c31\u66f4\u60f3\u8207\u4ed6\uff08\u5979\uff09\u5728\u4e00\u8d77\u3002\u5713\u7684\u4ea4\u758a\u4e5f\u8c61\u5fb5\u8457\u60f3\u6253\u7834\u5713\u672c\u8eab\u7684\u5f62\u72c0\uff0c\u4e5f\u5c31\u662f\u8c61\u5fb5\u8457\u60f3\u6253\u7834\u73fe\u72c0\u7684\u5fc3\u60c5\u3002\u4f60\u662f\u5426\u60f3\u904e\u4e0d\u540c\u65bc\u73fe\u5728\u7684\u751f\u6d3b\u65b9\u5f0f\uff0c\u537b\u56e0\u70ba\u627e\u4e0d\u5230\u5177\u9ad4\u5c0d\u7b56\u800c\u611f\u5230\u7126\u616e\uff0c\u800c\u4e14\u9019\u7a2e\u7126\u616e\u6709\u8d8a\u4f86\u8d8a\u56b4\u91cd\u7684\u50be\u5411\u3002',\n          scores: {\n            '\u6539\u8b8a\u617e\u671b': 88,\n            '\u89aa\u5bc6\u9700\u6c42': 85,\n            '\u4e0d\u6eff\u610f\u5ea6': 75,\n            '\u7126\u616e\u7a0b\u5ea6': 70\n          }\n        },\n        D: {\n          title: '\u5c0b\u6c42\u578b\u4eba\u683c',\n          description: '\u662f\u5426\u56e0\u70ba\u548c\u5176\u4ed6\u4eba\u7684\u4eba\u969b\u95dc\u4fc2\u4e0d\u9806\u5229\u800c\u6d88\u6c89\uff1f\u6240\u756b\u7684\u5713\u548c\u539f\u4f86\u7684\u5713\u5206\u96e2\u8c61\u5fb5\u8457\u4ed6\u4eba\u548c\u81ea\u5df1\u6c92\u6709\u95dc\u4fc2\u3002\u5fc3\u88e1\u6e34\u671b\u5c0b\u6c42\u597d\u670b\u53cb\uff0c\u6216\u662f\u5e0c\u671b\u548c\u67d0\u4eba\u6210\u70ba\u597d\u670b\u53cb\uff0c\u5f7c\u6b64\u4e4b\u9593\u53ef\u4ee5\u76f8\u4e92\u5e6b\u52a9\u3002',\n          scores: {\n            '\u5b64\u7368\u611f': 75,\n            '\u53cb\u8abc\u6e34\u671b': 90,\n            '\u4e92\u52a9\u7cbe\u795e': 85,\n            '\u95dc\u4fc2\u671f\u5f85': 88\n          }\n        }\n      };\n      \n      \/\/ \u6e2c\u9a57\u63a7\u5236\u5668\n      class QuizController {\n        constructor() {\n          this.currentAnswer = null;\n          this.quizContainer = document.querySelector('#personality-quiz-container');\n          this.pages = {\n            intro: this.quizContainer.querySelector('[data-page=\"intro\"]'),\n            questions: this.quizContainer.querySelector('[data-page=\"questions\"]'),\n            results: this.quizContainer.querySelector('[data-page=\"results\"]')\n          };\n          this.init();\n        }\n        \n        init() {\n          this.bindEvents();\n        }\n        \n        bindEvents() {\n          \/\/ \u958b\u59cb\u6e2c\u9a57\u6309\u9215\n          const startBtn = this.quizContainer.querySelector('[data-action=\"start-quiz\"]');\n          startBtn.addEventListener('click', () => this.startQuiz());\n          \n          \/\/ \u9078\u9805\u9ede\u64ca\n          const options = this.quizContainer.querySelectorAll('.option-item');\n          options.forEach(option => {\n            option.addEventListener('click', (e) => this.selectOption(e));\n          });\n          \n          \/\/ \u91cd\u65b0\u6e2c\u8a66\u6309\u9215\n          const restartBtn = this.quizContainer.querySelector('[data-action=\"restart-quiz\"]');\n          restartBtn.addEventListener('click', () => this.restartQuiz());\n        }\n        \n        startQuiz() {\n          this.showPage('questions');\n          this.scrollToTop();\n        }\n        \n        selectOption(e) {\n          const option = e.currentTarget;\n          const value = option.dataset.value;\n          const radio = option.querySelector('input[type=\"radio\"]');\n          \n          radio.checked = true;\n          this.currentAnswer = value;\n          \n          \/\/ \u5ef6\u9072\u63d0\u4ea4\u4ee5\u986f\u793a\u9078\u4e2d\u6548\u679c\n          setTimeout(() => {\n            this.submitQuiz();\n          }, 300);\n        }\n        \n        submitQuiz() {\n          if (!this.currentAnswer) return;\n          \n          this.showResults(this.currentAnswer);\n          this.scrollToTop();\n        }\n        \n        showResults(answer) {\n          const result = results[answer];\n          const resultText = this.quizContainer.querySelector('[data-result-text]');\n          \n          resultText.innerHTML = `\n            <h4 style=\"font-size: 22px; font-weight: 600; color: var(--primary-color); margin-bottom: 16px;\">\n              ${result.title}\n            <\/h4>\n            <p>${result.description}<\/p>\n          `;\n          \n          this.showPage('results');\n          \n          \/\/ \u5ef6\u9072\u986f\u793a\u5716\u8868\u4ee5\u78ba\u4fddcanvas\u53ef\u898b\n          setTimeout(() => {\n            this.createChart(result.scores);\n          }, 300);\n        }\n        \n        createChart(scores) {\n          const ctx = document.getElementById('personality-chart').getContext('2d');\n          \n          \/\/ \u6e05\u9664\u73fe\u6709\u5716\u8868\n          if (this.chart) {\n            this.chart.destroy();\n          }\n          \n          const labels = Object.keys(scores);\n          const data = Object.values(scores);\n          \n          this.chart = new Chart(ctx, {\n            type: 'radar',\n            data: {\n              labels: labels,\n              datasets: [{\n                label: '\u4f60\u7684\u7279\u8cea\u5206\u6790',\n                data: data,\n                fill: true,\n                backgroundColor: 'rgba(79, 70, 229, 0.2)',\n                borderColor: 'rgba(79, 70, 229, 1)',\n                pointBackgroundColor: 'rgba(79, 70, 229, 1)',\n                pointBorderColor: '#fff',\n                pointHoverBackgroundColor: '#fff',\n                pointHoverBorderColor: 'rgba(79, 70, 229, 1)',\n                borderWidth: 2\n              }]\n            },\n            options: {\n              responsive: true,\n              maintainAspectRatio: false,\n              scales: {\n                r: {\n                  beginAtZero: true,\n                  max: 100,\n                  ticks: {\n                    stepSize: 20,\n                    font: {\n                      size: 14\n                    }\n                  },\n                  pointLabels: {\n                    font: {\n                      size: 18,\n                      weight: '600'\n                    },\n                    padding: 20\n                  }\n                }\n              },\n              plugins: {\n                legend: {\n                  position: 'bottom',\n                  labels: {\n                    font: {\n                      size: 16\n                    },\n                    padding: 20\n                  }\n                },\n                tooltip: {\n                  callbacks: {\n                    label: function(context) {\n                      return context.dataset.label + ': ' + context.raw + '%';\n                    }\n                  },\n                  titleFont: {\n                    size: 16\n                  },\n                  bodyFont: {\n                    size: 14\n                  },\n                  padding: 12\n                }\n              }\n            }\n          });\n        }\n        \n        restartQuiz() {\n          this.currentAnswer = null;\n          \n          \/\/ \u91cd\u7f6e\u9078\u9805\n          const radios = this.quizContainer.querySelectorAll('input[type=\"radio\"]');\n          radios.forEach(radio => radio.checked = false);\n          \n          \/\/ \u92b7\u6bc0\u5716\u8868\n          if (this.chart) {\n            this.chart.destroy();\n            this.chart = null;\n          }\n          \n          this.showPage('intro');\n          this.scrollToTop();\n        }\n        \n        showPage(pageName) {\n          Object.values(this.pages).forEach(page => {\n            page.style.display = 'none';\n            page.style.opacity = '0';\n          });\n          \n          const page = this.pages[pageName];\n          page.style.display = 'block';\n          \n          \/\/ \u5f37\u5236\u91cd\u7e6a\n          page.offsetHeight;\n          \n          page.style.opacity = '1';\n        }\n        \n        scrollToTop() {\n          const container = this.quizContainer;\n          const containerTop = container.getBoundingClientRect().top + window.pageYOffset - 100;\n          \n          window.scrollTo({\n            top: containerTop,\n            behavior: 'smooth'\n          });\n        }\n      }\n      \n      \/\/ \u8f09\u5165 Chart.js\n      function loadChartJS(callback) {\n        if (typeof Chart !== 'undefined') {\n          callback();\n          return;\n        }\n        \n        const script = document.createElement('script');\n        script.src = 'https:\/\/cdnjs.cloudflare.com\/ajax\/libs\/Chart.js\/4.4.1\/chart.umd.min.js';\n        script.onload = callback;\n        document.head.appendChild(script);\n      }\n      \n      \/\/ \u521d\u59cb\u5316\n      function init() {\n        loadChartJS(() => {\n          new QuizController();\n        });\n      }\n      \n      \/\/ \u78ba\u4fdd DOM \u8f09\u5165\u5b8c\u6210\u5f8c\u521d\u59cb\u5316\n      if (document.readyState === 'loading') {\n        document.addEventListener('DOMContentLoaded', init);\n      } else {\n        init();\n      }\n    })();\n  <\/script>\n<\/div>","protected":false},"excerpt":{"rendered":"<p>\u8fd9\u4e2a\u6d4b\u9a8c\u53ef\u4ee5\u5224\u65ad\u4f60\u4e00\u5929\u7684\u5fc3\u60c5\u3002\u5706\u662f\u81ea\u5df1\u6216\u4ed6\u4eba\u4eba\u683c\u7684\u8c61\u5f81\uff0c\u968f\u624b\u6d82\u9e26\uff0c\u4ece\u5728\u539f\u6765\u7684\u4e00\u4e2a\u5706\u5982\u4f55\u52a0\u4e0a\u4e00\u4e2a\u65b0\u7684\u5706\uff0c\u53ef\u4ee5\u77e5\u9053\u4f60\u60f3\u5982\u4f55\u4e0e\u670b\u53cb\u4ea4\u5f80\u3002<\/p>","protected":false},"author":19,"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":"","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":[175],"tags":[],"class_list":["post-2717","post","type-post","status-publish","format-standard","hentry","category-relationships"],"_links":{"self":[{"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/posts\/2717","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\/19"}],"replies":[{"embeddable":true,"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/comments?post=2717"}],"version-history":[{"count":4,"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/posts\/2717\/revisions"}],"predecessor-version":[{"id":10626,"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/posts\/2717\/revisions\/10626"}],"wp:attachment":[{"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/media?parent=2717"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/categories?post=2717"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/xinliceyan.org\/zh\/wp-json\/wp\/v2\/tags?post=2717"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}