{"id":19728640,"url":"https://github.com/jypblue/vue-crumbs","last_synced_at":"2026-02-28T07:35:19.513Z","repository":{"id":57395445,"uuid":"79818301","full_name":"jypblue/vue-crumbs","owner":"jypblue","description":"a simple and useful breadcrumb for Vue2.js","archived":false,"fork":false,"pushed_at":"2018-08-26T09:22:04.000Z","size":50,"stargazers_count":14,"open_issues_count":1,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2026-01-17T08:34:51.520Z","etag":null,"topics":["breadcrumb","breadcrumbs","vue","vue-crumbs","vue-router2","vue2"],"latest_commit_sha":null,"homepage":"https://www.npmjs.com/package/vue-crumbs","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/jypblue.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2017-01-23T15:40:12.000Z","updated_at":"2024-07-24T09:32:02.000Z","dependencies_parsed_at":"2022-08-30T20:01:08.390Z","dependency_job_id":null,"html_url":"https://github.com/jypblue/vue-crumbs","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/jypblue/vue-crumbs","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jypblue%2Fvue-crumbs","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jypblue%2Fvue-crumbs/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jypblue%2Fvue-crumbs/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jypblue%2Fvue-crumbs/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/jypblue","download_url":"https://codeload.github.com/jypblue/vue-crumbs/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jypblue%2Fvue-crumbs/sbom","scorecard":{"id":545825,"data":{"date":"2025-08-11","repo":{"name":"github.com/jypblue/vue-crumbs","commit":"35168f024813a8732d2eee29fc881a34724b41e5"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":1.7,"checks":[{"name":"Token-Permissions","score":-1,"reason":"No tokens found","details":null,"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"name":"Pinned-Dependencies","score":-1,"reason":"no dependencies found","details":null,"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}},{"name":"SAST","score":0,"reason":"no SAST tool detected","details":["Warn: no pull requests merged into dev branch"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"Maintained","score":0,"reason":"0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Code-Review","score":0,"reason":"Found 0/17 approved changesets -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"name":"Dangerous-Workflow","score":-1,"reason":"no workflows found","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#binary-artifacts"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: MIT License: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Signed-Releases","score":-1,"reason":"no releases found","details":null,"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":0,"reason":"branch protection not enabled on development/release branches","details":["Warn: branch protection not enabled for branch 'master'"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"name":"Vulnerabilities","score":0,"reason":"56 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-6chw-6frg-f759","Warn: Project is vulnerable to: GHSA-v88g-cgmw-v5xw","Warn: Project is vulnerable to: GHSA-93q8-gq69-wqmw","Warn: Project is vulnerable to: GHSA-fwr7-v2mv-hh25","Warn: Project is vulnerable to: GHSA-67hx-6x53-jw92","Warn: Project is vulnerable to: GHSA-v6h2-p8h4-qcjw","Warn: Project is vulnerable to: GHSA-grv7-fg5c-xmjg","Warn: Project is vulnerable to: GHSA-x9w5-v3q2-3rhw","Warn: Project is vulnerable to: GHSA-c6rq-rjc2-86v2","Warn: Project is vulnerable to: GHSA-3xgq-45jj-v275","Warn: Project is vulnerable to: GHSA-w573-4hg7-7wgq","Warn: Project is vulnerable to: GHSA-vh7m-p724-62c2","Warn: Project is vulnerable to: GHSA-r9p9-mrjm-926w","Warn: Project is vulnerable to: GHSA-434g-2637-qmqr","Warn: Project is vulnerable to: GHSA-49q7-c7j4-3p7m","Warn: Project is vulnerable to: GHSA-977x-g7h5-7qgw","Warn: Project is vulnerable to: GHSA-f7q4-pwc6-w24p","Warn: Project is vulnerable to: GHSA-fc9h-whq2-v747","Warn: Project is vulnerable to: GHSA-vjh7-7g9h-fjfh","Warn: Project is vulnerable to: GHSA-8r6j-v8pm-fqw3","Warn: Project is vulnerable to: MAL-2023-462","Warn: Project is vulnerable to: GHSA-43f8-2h32-f4cj","Warn: Project is vulnerable to: GHSA-qqgx-2p2h-9c37","Warn: Project is vulnerable to: GHSA-9c47-m6qq-7p4h","Warn: Project is vulnerable to: GHSA-6c8f-qphg-qjgp","Warn: Project is vulnerable to: GHSA-76p3-8jx3-jpfq","Warn: Project is vulnerable to: GHSA-jf85-cpcp-j695","Warn: Project is vulnerable to: GHSA-fvqr-27wr-82fm","Warn: Project is vulnerable to: GHSA-4xc9-xhrj-v574","Warn: Project is vulnerable to: GHSA-x5rq-j2xg-h7qm","Warn: Project is vulnerable to: GHSA-p6mc-m468-83gw","Warn: Project is vulnerable to: GHSA-29mw-wpgm-hmr9","Warn: Project is vulnerable to: GHSA-35jh-r3h4-6jhm","Warn: Project is vulnerable to: GHSA-4xcv-9jjx-gfj3","Warn: Project is vulnerable to: GHSA-952p-6rrq-rcjv","Warn: Project is vulnerable to: GHSA-f8q6-p94x-37v3","Warn: Project is vulnerable to: GHSA-vh95-rmgr-6w4m","Warn: Project is vulnerable to: GHSA-xvch-5gv4-984h","Warn: Project is vulnerable to: GHSA-fhjf-83wg-r2j9","Warn: Project is vulnerable to: GHSA-r96c-57pf-9jjm","Warn: Project is vulnerable to: GHSA-h7cp-r72f-jxh6","Warn: Project is vulnerable to: GHSA-v62p-rq8g-8h59","Warn: Project is vulnerable to: GHSA-gcx4-mw62-g8wm","Warn: Project is vulnerable to: GHSA-c2qf-rxjj-qqgw","Warn: Project is vulnerable to: GHSA-4g88-fppr-53pp","Warn: Project is vulnerable to: GHSA-4jqc-8m5r-9rpr","Warn: Project is vulnerable to: GHSA-3jfq-g458-7qm9","Warn: Project is vulnerable to: GHSA-r628-mhmh-qjhw","Warn: Project is vulnerable to: GHSA-9r2w-394v-53qc","Warn: Project is vulnerable to: GHSA-5955-9wpr-37jh","Warn: Project is vulnerable to: GHSA-qq89-hq3f-393p","Warn: Project is vulnerable to: GHSA-f5x3-32g6-xq36","Warn: Project is vulnerable to: GHSA-52f5-9888-hmc6","Warn: Project is vulnerable to: GHSA-5j4c-8p2g-v4jx","Warn: Project is vulnerable to: GHSA-c4w7-xm78-47vh","Warn: Project is vulnerable to: GHSA-p9pc-299p-vxgp"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-20T09:28:04.643Z","repository_id":57395445,"created_at":"2025-08-20T09:28:04.644Z","updated_at":"2025-08-20T09:28:04.644Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":29927605,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-02-27T19:37:42.220Z","status":"online","status_checked_at":"2026-02-28T02:00:07.010Z","response_time":90,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["breadcrumb","breadcrumbs","vue","vue-crumbs","vue-router2","vue2"],"created_at":"2024-11-12T00:06:34.128Z","updated_at":"2026-02-28T07:35:19.497Z","avatar_url":"https://github.com/jypblue.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# vue-crumbs\n[![Version](https://img.shields.io/npm/v/vue-crumbs.svg)](https://www.npmjs.com/package/vue-crumbs) [![License](https://img.shields.io/npm/l/vue-crumbs.svg)](https://www.npmjs.com/package/vue-crumbs) [![Downloads](https://img.shields.io/npm/dt/vue-crumbs.svg)](https://www.npmjs.com/package/vue-crumbs)\n\na simple and useful breadcrumbs for Vue2.js\n\n\n## Features\n\n- Supports the vue-router 2.x.x\n- Supports params routes\n- Supports latest Firefox, Chrome, Safari, Opera and IE9+\n- Compact size 2KB (1KB gzipped)\n\n## Installation\n\n### NPM\n\n```\n$ npm install vue-crumbs --save\n```\n\n### Bower\n\n```\n$ bower install vue-crumbs\n```\n\n### Crumbs Attributes（组件属性）\n\n| 参数        | 说明           | 类型               | 默认值       |\n|------------|----------------|--------------------|--------------|\n| mode    | 面包屑模式，可选值为`name` `url` `mix`;`name`按照router命名模式配置面包屑，支持params路由，`url`自定义路由配置面包屑(之前的实现方式），`mix`混合模式，但是（一条完整的路径必须完整按`name` 或者`url`模式中的一个来配置，不能交叉配置）  | String | mix    |\n| rightIcon | 间隔Icon | String | rightIcon   |\n\n### Routes Meta BreadCrumb Attributes （breadcrumb面包屑配置属性）\n| 参数        | 说明           | 类型               | 默认值       |\n|------------|----------------|--------------------|--------------|\n| icon | 面包屑名称图标 | String | 无   |\n| url  | 自定义URL（适用于`url`,`mix`模式） | String | 无  |\n| name | 面包屑名称  | String | 无   |\n| hidden | 是否隐藏  | Boolean | false   |\n\n\n### How To Use\n\n```\n\nImport:\nimport Vue from 'vue'\nimport VueCrumbs from 'vue-crumbs'\nVue.use(VueCrumbs)\n\nComponent Use:\n\u003cbreadcrumb rightIcon=\"fa fa-xxx\" mode=\"mix\"\u003e\u003c/breadcrumb\u003e\n\nRoutes Config:\njust like the Example below\n```\n\n\n### Example That Use In vue-cli\n\nroutes.js:\n\nurl mode config\n\n```\nconst routes = {\n  routes:[{\n    path:'/',\n    component:page,\n    meta:{\n    breadcrumb:[{\n      hidden:true, //if hidden is true ,current page breadcrumbs will be hidden\n      url:'/',\n      icon: '',\n      name: 'Home Page'\n    }]\n    },\n    children:[{\n      path:'admin',\n      component:admin,\n      meta:{\n        parent:'/',\n        breadcrumb:[{\n          url: '/admin',\n          icon: '',\n          name: 'admin page'\n        }]\n      }\n    }]\n  },{\n    path:'/foo',\n    component:foo,\n     // if it is a query or param route\n    beforeEnter: (to, from, next) =\u003e {\n      to \u0026\u0026 (to.meta.breadcrumb[0].url = to.fullPath);\n      window.sessionStorage.setItem('foo',to.fullPath);\n      next();\n    },\n    meta:{\n      parent:'/',\n      breadcrumb:[{\n        url: window.sessionStorage.getItem('foo'),\n        name: 'foo Page'\n      }]\n    }\n  },{\n    path:'/foo/detail',\n    component: detail,\n    meta:{\n      parent:'/foo',\n      breadcrumb:[{\n        url: '/foo/detail',\n        icon: '',\n        name: 'detail Page'\n      }]\n    }\n  },{\n    path:'/bar',\n    component:bar,\n    meta:{\n      parent: '/',\n      breadcrumb:[{\n        name: 'bar page' //if no url,it will get current page url as \u003crouter-link\u003e path\n      }]\n    }\n  }]\n };\nexport default routes;\n\n```\nname mode config(support params routes)\n\n```\nURL: /admin/:pid/:cid\n\nconst routes = {\n  routes:[{\n    path:'/',\n    component:page,\n    name: 'home'\n    meta:{\n\t    breadcrumb:{\n\t    \ticon: '',\n\t    \thidden: true,\n\t     \tname: 'Home Page'\n\t    }\n    },\n    children:[{\n      path:'admin/:pid',\n      component:admin,\n      name: 'admin',\n      meta:{\n        parent:'home',\n        breadcrumb:{\n        \ticon: '',\n         \tname: 'admin page'\n        }\n      }\n    },{\n    \tpath: 'admin/:pid/:cid',\n    \tcomponent: child,\n    \tname: 'child',\n    \tmeta: {\n    \t\tparent: 'admin',\n    \t\tbreadcrumb: {\n    \t\t\ticon: '',\n    \t\t\tname: 'child page'\n    \t\t}\n    \t}\n    }]\n  },\n  ]}\n\n```\n\nmix mode config:\n\n```\nURL: \n-  /admin/:pid/:cid =\u003e name mode\n-  /foo/detail =\u003e url mode\nconst routes = {\n  routes:[{\n    path:'/',\n    component:page,\n    name: 'home'\n    meta:{\n    breadcrumb:{\n    \ticon: '',\n    \thidden: true,\n     \tname: 'Home Page'\n    }\n    },\n    children:[{\n      path:'admin/:pid',\n      component:admin,\n      name: 'admin',\n      meta:{\n        parent:'home',\n        breadcrumb:{\n        \ticon: '',\n         \tname: 'admin page'\n        }\n      }\n    },{\n    \tpath: 'admin/:pid/:cid',\n    \tcomponent: child,\n    \tname: 'child',\n    \tmeta: {\n    \t\tparent: 'admin',\n    \t\tbreadcrumb: {\n    \t\t\ticon: '',\n    \t\t\tname: 'child page'\n    \t\t}\n    \t}\n    }]\n  },{\n    path:'/foo',\n    component:foo,\n\t meta:{\n      parent:'/',\n      breadcrumb:[{\n        url: '/foo',\n        name: 'foo Page'\n      }]\n    }\n  },{\n    path:'/foo/detail',\n    component: detail,\n    meta:{\n      parent:'/foo',\n      breadcrumb:[{\n        url: '/foo/detail',\n        icon: '',\n        name: 'detail Page'\n      }]\n    }\n  },\n  ]}\n\n```\n\n\n\nmain.js:\n\n```\nimport Vue from 'vue'\nimport VueRouter from 'vue-router'\nimport VueCrumbs from 'vue-crumbs'\nimport routes from './routes'\nimport App from './App'\n\nVue.use(VueRouter)\nVue.use(VueCrumbs)\nconst router = new VueRouter(routes)\n\nconst vm = new Vue({\n  router,\n  template: '\u003cApp/\u003e',\n  components: {\n    App\n  }\n})\n```\n\nApp.vue:\n\n```\n\u003ctemplate\u003e\n  \u003cdiv id=\"app\"\u003e\n    \u003cbreadcrumb\u003e\u003c/breadcrumb\u003e\n  \u003c/div\u003e\n\u003c/template\u003e\n\u003cscript\u003e\n  export default {\n    name: 'app'\n  }\n\u003c/script\u003e\n\u003cstyle\u003e\n\u003c/style\u003e\n```\n\n## Contribution\n\nWelcome to report issue and fork it\n\n## License\n\n[MIT](http://opensource.org/licenses/MIT)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjypblue%2Fvue-crumbs","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fjypblue%2Fvue-crumbs","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjypblue%2Fvue-crumbs/lists"}